JDK5.0 特性 监控与管理虚拟机
来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291465.html
import java.lang.management.ClassLoadingMXBean;
import java.lang.management.CompilationMXBean;
import java.lang.management.GarbageCollectorMXBean;
import java.lang.management.ManagementFactory;
import java.lang.management.MemoryMXBean;
import java.lang.management.OperatingSystemMXBean;
import java.lang.management.RuntimeMXBean;
import java.lang.management.ThreadMXBean;
import java.util.List;
/**
本例介绍如何监控和管理Java虚拟机,包括获取Java虚拟机的内存使用情况、线程数、运行时间等。
在J2SE5.0中使用Bean监控和管理Java虚拟机,java.lang.management.ManagementFactory是管理Bean的工厂类,
通过它的get系列方法能够获得不同的管理Bean的实例。
1. java.lang.management.MemoryMXBean: 该Bean用于管理Java虚拟机的内存系统。
一个Java虚拟机具有一个实例。
2.java.lang.management.ClassLoadingMXBean: 该Bean用于管理Java虚拟机的类加载系统。
一个Java虚拟机具有一个实例。
3.java.lang.management.TreadMXBean: 该Bean用于管理Java虚拟机的线程系统。
一个Java虚拟机具有一个实例。
4.java.lang.management.RuntimeMXBean: 该Bean用于管理Java虚拟机的线程系统。
一个Java虚拟机具有一个实例。
5.java.lang.management.OperatingSystemMXBean: 该Bean用于管理操作系统。
一个Java虚拟机具有一个实例。
6.java.lang.management.CompilationMXBean: 该Bean用于管理Java虚拟机的编译系统。
一个Java虚拟机具有一个实例。
7.java.lang.management.GarbageCollectorMXBean: 该Bean用于管理Java虚拟机的垃圾回收系统。
一个Java虚拟机具有一个或者多个实例。
*/
public class JDKMBean {
public static void printMemoryMXBean(){
//获得单一实例
MemoryMXBean instance = ManagementFactory.getMemoryMXBean();
System.out.printf("%n---%s---%n",instance.getClass().getName());
//返回用于对象分配的堆的当前内存使用量
System.out.printf("%s: %s%n","HeapMemoryUsage",instance.getHeapMemoryUsage());
//返回Java虚拟机使用的非堆内存的当前使用量
System.out.printf("%s: %s%n","getNonHeapMemoryUsage",instance.getNonHeapMemoryUsage());
instance.gc();
}
public static void printClassLoadingMXBean(){
//获得单一实例
ClassLoadingMXBean instance = ManagementFactory.getClassLoadingMXBean();
System.out.printf("%n---%s---%n",instance.getClass().getName());
//返回当前加载到Java虚拟机中的类的数量
System.out.printf("%s: %s%n","LoadedClassCount",instance.getLoadedClassCount());
//返回自Java虚拟机开始执行到目前已经加载的类的总数
System.out.printf("%s: %s%n","TotalLoadedClassCount",instance.getTotalLoadedClassCount());
//返回自Java虚拟机开始执行到目前已经卸载的类的总数
System.out.printf("%s: %s%n","UnloadedLoadedClassCount",instance.getUnloadedClassCount());
}
public static void printThreadMXBean(){
//获得单一实例
ThreadMXBean instance = ManagementFactory.getThreadMXBean();
System.out.printf("%n---%s---%n",instance.getClass().getName());
//返回活动线程的当前数目,包括守护线程和非守护线程
System.out.printf("%s: %s%n","ThreadCount",instance.getThreadCount());
//返回活动线程ID
System.out.printf("%s: %n","Thread IDs");
long[] ids = instance.getAllThreadIds();
for(long id : ids){
System.out.printf("%s; ", id);
}
System.out.println();
//返回活动守护线程的当前数目
System.out.printf("%s: %s%n","DaemonThreadCount",instance.getDaemonThreadCount());
//返回自从java虚拟机启动或峰值重置以来峰值活动线程计数
System.out.printf("%s: %s%n","PeakThreadCount",instance.getPeakThreadCount());
//返回当前线程的总CPU时间
System.out.printf("%s: %s%n","CurrentCpuTime",instance.getCurrentThreadCpuTime());
//返回当前线程在用户模式中执行的CPU时间
System.out.printf("%s: %s%n","CurrentThreadCpuTime",instance.getCurrentThreadUserTime());
}
public static void printRuntimeMXBean(){
//获得单一实例
RuntimeMXBean instance = ManagementFactory.getRuntimeMXBean();
System.out.printf("%n---%s---%n",instance.getClass().getName());
//返回由引导类加载器用于搜索类文件的引导类路径
System.out.printf("%s: %s%n","BootClassPath",instance.getBootClassPath());
//返回系统类加载器用于搜索类文件的Java类路径
System.out.printf("%s: %s%n","ClassPath",instance.getClassPath());
//引用传递给Java虚拟机的输入变量,其中不包括传递给main方法的变量
System.out.printf("%s: %n","InputArguments");
List<String> args = instance.getInputArguments();
for(String arg : args){
System.out.printf("%s; ",arg);
}
//返回Java库路径
System.out.printf("%s: %s%n","LibraryPath",instance.getLibraryPath());
//返回正在运行的Java虚拟机实现的管理接口的规范版本
System.out.printf("%s: %s%n","ManagementSpecVersion",instance.getManagementSpecVersion());
//返回正在运行的Java虚拟机的名称
System.out.printf("%s: %s%n","Name",instance.getName());
//返回Java虚拟机规范名称
System.out.printf("%s: %s%n","SpecName",instance.getSpecName());
//返回Java虚拟机规范提供商
System.out.printf("%s: %s%n","SpecVendor",instance.getSpecVendor());
//返回Java虚拟机规范版本
System.out.printf("%s: %s%n","SpecVersion",instance.getSpecVersion());
//返回Java虚拟机实现名称
System.out.printf("%s: %s%n","VmName",instance.getVmName());
//返回Java虚拟机实现提供商
System.out.printf("%s: %s%n","VmVendor",instance.getVmVendor());
//返回Java虚拟机实现版本
System.out.printf("%s: %s%n","VmVersion",instance.getVmVersion());
//返回Java虚拟机的启动时间
System.out.printf("%s: %s%n","startTime",instance.getStartTime());
//返回Java虚拟机的正常运行时间
System.out.printf("%s: %s%n","Uptime",instance.getUptime());
}
public static void printOperatingSystemMXBean(){
//获得单一实例
OperatingSystemMXBean instance = ManagementFactory.getOperatingSystemMXBean();
System.out.printf("%n---%s---%n",instance.getClass().getName());
//返回操作系统的架构
System.out.printf("%s: %s%n","Arch",instance.getArch());
//返回Java虚拟机可以使用的处理器数目
System.out.printf("%s: %s%n","AvailableProcessors",instance.getAvailableProcessors());
//返回操作系统名称
System.out.printf("%s: %s%n","Name",instance.getName());
//返回操作系统版本
System.out.printf("%s: %s%n","Version",instance.getVersion());
}
public static void printCompilationMXBean(){
//获得单一实例
CompilationMXBean instance = ManagementFactory.getCompilationMXBean();
System.out.printf("%n---%s---%n",instance.getClass().getName());
//返回即时(JIT)编译器的名称
System.out.printf("%s: %s%n","JIT",instance.getName());
//返回在编译上花费的累积耗费时间的近似值
System.out.printf("%s: %s%n","TotalCompilationTime",instance.getTotalCompilationTime());
}
public static void printGargageCollectorMXBean(){
//获得单一实例
List<GarbageCollectorMXBean> instances = ManagementFactory.getGarbageCollectorMXBeans();
System.out.printf("%n---%s---%n",GarbageCollectorMXBean.class.getName());
//遍历每个实例
for(GarbageCollectorMXBean instance : instances){
//返回垃圾收集器的名字
System.out.printf("***%s: %s***%n","Name",instance.getName());
//返回已发生的回收的总次数
System.out.printf("%s: %s%n","CollectionCount",instance.getCollectionCount());
//返回近似的累积回收时间
System.out.printf("%s: %s%n","CollectionTime",instance.getCollectionTime());
}
}
public static void main(String[] args){
JDKMBean.printMemoryMXBean();
JDKMBean.printClassLoadingMXBean();
JDKMBean.printThreadMXBean();
JDKMBean.printRuntimeMXBean();
JDKMBean.printOperatingSystemMXBean();
JDKMBean.printCompilationMXBean();
JDKMBean.printGargageCollectorMXBean();
}
}
JDK5.0 特性 监控与管理虚拟机的更多相关文章
- JDK5.0 特性-线程同步装置之Semaphore
来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291474.html import java.util.ArrayList; import j ...
- JDK5.0 特性-线程锁Lock
来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291470.html import java.util.concurrent.Executor ...
- JDK5.0特性-线程 Callable和Future
来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291466.html import java.util.concurrent.Callable ...
- JDK5.0 特性线程 同步装置之CountDownLatch 同步装置之CyclicBarrier 线程 BlockingQueue
来自:http://www.cnblogs.com/taven/category/475298.html import java.util.concurrent.CountDownLatch; imp ...
- JDK5.0 特性-线程 Condition
来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291471.html import java.util.concurrent.Executor ...
- JDK5.0 特性-线程任务执行架构 ScheduledExecutorService
来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291469.html import java.util.concurrent.Callable ...
- JDK5.0特性,使用ProcessBuilder执行本地命令
import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.IO ...
- 集合框架-工具类-JDK5.0特性-函数可变参数
1 package cn.itcast.p4.news.demo; 2 3 public class ParamterDemo { 4 5 public static void main(String ...
- 集合框架-工具类-JDK5.0特性-ForEach循环
1 package cn.itcast.p4.news.demo; 2 3 import java.util.ArrayList; 4 import java.util.HashMap; 5 impo ...
随机推荐
- JavaScript操作DOM(动态表格处理)
<html> <title>动态处理表格数据</title> <head> <script type="text/javascript& ...
- addEventListener 的一些好方法 简单粗暴的说给你
function show(){ document.addEventListener("click",fn,{ "passive":false, "c ...
- Any way to start Google Chrome in headless mode?
Any way to start Google Chrome in headless mode? - Stack Overflow Any way to start Google Chrome in ...
- POJ 1470 Closest Common Ancestors (LCA,离线Tarjan算法)
Closest Common Ancestors Time Limit: 2000MS Memory Limit: 10000K Total Submissions: 13372 Accept ...
- mysql 3.2.49 源代码安装-redhat 5 x64
[mysql@localhost ~]$ uname -r2.6.32 [root@localhost ~]#cp /usr/include/pthread.h /usr/include/pthrea ...
- C#编程(十一)----------C#编程规范
C#编程规范 1.要使一个代码块内的代码都同意缩进一个tab键长度 2.有下列情况下建议有换行 方法之间: 局部变量和它后边的语句之间: 方法内的功能逻辑部分之间: 3.{和}要单起一行 4.每行建议 ...
- Android 面试题(答案最全)
1. Android dvm的进程和Linux的进程, 应用程序的进程是否为同一个概念DVM指dalivk的虚拟机.每一个Android应用程序都在它自己的进程中运行,都拥有一个独立的Dalvik虚拟 ...
- 转 dockerfile 介绍 及 编写
Docker简介 Docker项目提供了构建在Linux内核功能之上,协同在一起的的高级工具.其目标是帮助开发和运维人员更容易地跨系统跨主机交付应用程序和他们的依赖.Docker通过Docker容器, ...
- Dwz手册的补充说明和常见问题
1.我如何在项目中使用dwz? 手册中有如下说明: 设计思路 第一次打开页面时载入界面到客户端, 之后和服务器的交互只是数据交互, 不占用界面相关的网络流量. 支持HTML扩展方式来调用DWZ组件. ...
- Eclipse调试:改变颜色, 背景与字体大小 和xml字体调整
http://blog.csdn.net/qq272803220/article/details/7292699 eclipse操作界面默认颜色为白色.对于我们长期使用电脑编程的人来说,白色很刺激我们 ...