【转】java使用java.lang.management监视和管理 Java 虚拟机
原文地址:https://blog.csdn.net/zhongweijian/article/details/7619383
软件包 java.lang.management
提供管理接口,用于监视和管理 Java 虚拟机以及 Java 虚拟机在其上运行的操作系统。
接口摘要
| ClassLoadingMXBean | 用于 Java 虚拟机的类加载系统的管理接口。 |
| CompilationMXBean | 用于 Java 虚拟机的编译系统的管理接口。 |
| GarbageCollectorMXBean | 用于 Java 虚拟机的垃圾回收的管理接口。 |
| MemoryManagerMXBean | 内存管理器的管理接口。 |
| MemoryMXBean | Java 虚拟机的内存系统的管理接口。 |
| MemoryPoolMXBean | 内存池的管理接口。 |
| OperatingSystemMXBean | 用于操作系统的管理接口,Java 虚拟机在此操作系统上运行。 |
| RuntimeMXBean | Java 虚拟机的运行时系统的管理接口。 |
| ThreadMXBean |
Java 虚拟机线程系统的管理接口。 |
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.MemoryManagerMXBean;import java.lang.management.MemoryPoolMXBean;import java.lang.management.MemoryUsage;import java.lang.management.OperatingSystemMXBean;import java.lang.management.RuntimeMXBean;import java.lang.management.ThreadMXBean;import java.util.List;import javax.management.MBeanServerConnection;public class MBeanDemo {public static void main(String[] args) {showJvmInfo();showMemoryInfo();showSystem();showClassLoading();showCompilation();showThread();showGarbageCollector();showMemoryManager();showMemoryPool();}/*** Java 虚拟机的运行时系统*/public static void showJvmInfo() {RuntimeMXBean mxbean = ManagementFactory.getRuntimeMXBean();String vendor = mxbean.getVmVendor();System.out.println("jvm name:" + mxbean.getVmName());System.out.println("jvm version:" + mxbean.getVmVersion());System.out.println("jvm bootClassPath:" + mxbean.getBootClassPath());System.out.println("jvm start time:" + mxbean.getStartTime());}/*** Java 虚拟机的内存系统*/public static void showMemoryInfo() {MemoryMXBean mem = ManagementFactory.getMemoryMXBean();MemoryUsage heap = mem.getHeapMemoryUsage();System.out.println("Heap committed:" + heap.getCommitted() + " init:" + heap.getInit() + " max:"+ heap.getMax() + " used:" + heap.getUsed());}/*** Java 虚拟机在其上运行的操作系统*/public static void showSystem() {OperatingSystemMXBean op = ManagementFactory.getOperatingSystemMXBean();System.out.println("Architecture: " + op.getArch());System.out.println("Processors: " + op.getAvailableProcessors());System.out.println("System name: " + op.getName());System.out.println("System version: " + op.getVersion());System.out.println("Last minute load: " + op.getSystemLoadAverage());}/*** Java 虚拟机的类加载系统*/public static void showClassLoading(){ClassLoadingMXBean cl = ManagementFactory.getClassLoadingMXBean();System.out.println("TotalLoadedClassCount: " + cl.getTotalLoadedClassCount());System.out.println("LoadedClassCount" + cl.getLoadedClassCount());System.out.println("UnloadedClassCount:" + cl.getUnloadedClassCount());}/*** Java 虚拟机的编译系统*/public static void showCompilation(){CompilationMXBean com = ManagementFactory.getCompilationMXBean();System.out.println("TotalCompilationTime:" + com.getTotalCompilationTime());System.out.println("name:" + com.getName());}/*** Java 虚拟机的线程系统*/public static void showThread(){ThreadMXBean thread = ManagementFactory.getThreadMXBean();System.out.println("ThreadCount" + thread.getThreadCount());System.out.println("AllThreadIds:" + thread.getAllThreadIds());System.out.println("CurrentThreadUserTime" + thread.getCurrentThreadUserTime());//......还有其他很多信息}/*** Java 虚拟机中的垃圾回收器。*/public static void showGarbageCollector(){List<GarbageCollectorMXBean> gc = ManagementFactory.getGarbageCollectorMXBeans();for(GarbageCollectorMXBean GarbageCollectorMXBean : gc){System.out.println("name:" + GarbageCollectorMXBean.getName());System.out.println("CollectionCount:" + GarbageCollectorMXBean.getCollectionCount());System.out.println("CollectionTime" + GarbageCollectorMXBean.getCollectionTime());}}/*** Java 虚拟机中的内存管理器*/public static void showMemoryManager(){List<MemoryManagerMXBean> mm = ManagementFactory.getMemoryManagerMXBeans();for(MemoryManagerMXBean eachmm: mm){System.out.println("name:" + eachmm.getName());System.out.println("MemoryPoolNames:" + eachmm.getMemoryPoolNames().toString());}}/*** Java 虚拟机中的内存池*/public static void showMemoryPool(){List<MemoryPoolMXBean> mps = ManagementFactory.getMemoryPoolMXBeans();for(MemoryPoolMXBean mp : mps){System.out.println("name:" + mp.getName());System.out.println("CollectionUsage:" + mp.getCollectionUsage());System.out.println("type:" + mp.getType());}}/*** 访问 MXBean 的方法的三种方法*/public static void visitMBean(){//第一种直接调用同一 Java 虚拟机内的 MXBean 中的方法。RuntimeMXBean mxbean = ManagementFactory.getRuntimeMXBean();String vendor1 = mxbean.getVmVendor();System.out.println("vendor1:" + vendor1);//第二种通过一个连接到正在运行的虚拟机的平台 MBeanServer 的 MBeanServerConnection。MBeanServerConnection mbs = null;// Connect to a running JVM (or itself) and get MBeanServerConnection// that has the JVM MXBeans registered in it/*try {// Assuming the RuntimeMXBean has been registered in mbsObjectName oname = new ObjectName(ManagementFactory.RUNTIME_MXBEAN_NAME);String vendor2 = (String) mbs.getAttribute(oname, "VmVendor");System.out.println("vendor2:" + vendor2);} catch (Exception e) {e.printStackTrace();}*///第三种使用 MXBean 代理// MBeanServerConnection mbs3 = null;// RuntimeMXBean proxy;// try {// proxy = ManagementFactory.newPlatformMXBeanProxy(mbs3,ManagementFactory.RUNTIME_MXBEAN_NAME,// RuntimeMXBean.class);// String vendor = proxy.getVmVendor();// } catch (IOException e) {// e.printStackTrace();// }}}
输出:
jvm name:Java HotSpot(TM) Client VMjvm version:1.6.0-b105jvm bootClassPath:C:\Program Files\Java\jdk1.6.0\jre\lib\resources.jar;C:\Program Files\Java\jdk1.6.0\jre\lib\rt.jar;C:\Program Files\Java\jdk1.6.0\jre\lib\sunrsasign.jar;C:\Program Files\Java\jdk1.6.0\jre\lib\jsse.jar;C:\Program Files\Java\jdk1.6.0\jre\lib\jce.jar;C:\Program Files\Java\jdk1.6.0\jre\lib\charsets.jar;C:\Program Files\Java\jdk1.6.0\jre\classesjvm start time:1307440032774Heap committed:5177344 init:0 max:66650112 used:632640Architecture: x86Processors: 2System name: Windows XPSystem version: 5.1Last minute load: -1.0TotalLoadedClassCount: 381LoadedClassCount381UnloadedClassCount:0TotalCompilationTime:3name:HotSpot Client CompilerThreadCount5AllThreadIds:[J@47b480CurrentThreadUserTime15625000name:CopyCollectionCount:0CollectionTime0name:MarkSweepCompactCollectionCount:0CollectionTime0name:CodeCacheManagerMemoryPoolNames:[Ljava.lang.String;@1389e4name:CopyMemoryPoolNames:[Ljava.lang.String;@c20e24name:MarkSweepCompactMemoryPoolNames:[Ljava.lang.String;@2e7263name:Code CacheCollectionUsage:nulltype:Non-heap memoryname:Eden SpaceCollectionUsage:init = 917504(896K) used = 0(0K) committed = 0(0K) max = 4194304(4096K)type:Heap memoryname:Survivor SpaceCollectionUsage:init = 65536(64K) used = 0(0K) committed = 0(0K) max = 458752(448K)type:Heap memoryname:Tenured GenCollectionUsage:init = 4194304(4096K) used = 0(0K) committed = 0(0K) max = 61997056(60544K)type:Heap memoryname:Perm GenCollectionUsage:init = 12582912(12288K) used = 0(0K) committed = 0(0K) max = 67108864(65536K)type:Non-heap memoryname:Perm Gen [shared-ro]CollectionUsage:init = 8388608(8192K) used = 0(0K) committed = 0(0K) max = 8388608(8192K)type:Non-heap memoryname:Perm Gen [shared-rw]CollectionUsage:init = 12582912(12288K) used = 0(0K) committed = 0(0K) max = 12582912(12288K)type:Non-heap memory
【转】java使用java.lang.management监视和管理 Java 虚拟机的更多相关文章
- java使用java.lang.management监视和管理 Java 虚拟机
ClassLoadingMXBean 用于 Java 虚拟机的类加载系统的管理接口. CompilationMXBean 用于 Java 虚拟机的编译系统的管理接口. GarbageCollector ...
- Java 监控基础 - 使用 JMX 监控和管理 Java 程序
点赞再看,动力无限.Hello world : ) 微信搜「程序猿阿朗 」. 本文 Github.com/niumoo/JavaNotes 和 未读代码网站 已经收录,有很多知识点和系列文章. 此篇文 ...
- 远程监视jboss应用java内存的配置
前言 因为最近一个项目部署在客户那边运行一个月左右就会出现java内存溢出的问题,为了时时监控java内存的情况需要,需要远程查看服务器上java内存的一些情况.在公司模拟部署了远程监视linux下项 ...
- 远程监视jboss应用java内存的配置(实测) .
前言 因为最近一个项目部署在客户那边运行一个月左右就会出现java内存溢出的问题,为了时时监控java内存的情况需要,需要远程查看服务器上java内存的一些情况.在公司模拟部署了远程监视linux下项 ...
- Java Business Process Management(业务流程管理) 初识环境搭建
一.简介 (一)什么是jbpm JBPM,全称是Java Business Process Management(业务流程管理),它是覆盖了业务流程管理.工作流.服务协作等领域的一个开源的.灵活的.易 ...
- 前台传参数时间类型不匹配:type 'java.lang.String' to required type 'java.util.Date' for property 'createDate'
springMVC action接收参数: org.springframework.validation.BindException: org.springframework.validation.B ...
- Cannot convert value of type [java.lang.String] to required type [java.util.Date] for property 'xxx': no matching editors or conversion strategy found
今天在完成项目的时候遇到了下面的异常信息: 04-Aug-2014 15:49:27.894 SEVERE [http-apr-8080-exec-5] org.apache.catalina.cor ...
- paip.自动import的实现跟java.lang.SecurityException Prohibited package name java
paip.自动import的实现跟java.lang.SecurityException Prohibited package name java #-----自动import 因为java.lang ...
- Error: java.lang.UnsatisfiedLinkError: no ntvinv in java.library.path
Error Message When compiling or executing a Java application that uses the ArcObjects Java API, the ...
随机推荐
- symantec SMG 抓包
1.使用putty连接SMG,先用admin账号登陆 执行set-support , 设置一个密码. 2.重新打开一个putty连接SMG,使用support账号登陆.用我们刚才设置的密码. 3.开 ...
- leetcode上回溯法的使用
17 93 131 46(全排列) class Solution { public: vector<vector<int>> permute(vector<int> ...
- python 的装饰器,
昨天去面试,发现了装饰器还是不太熟悉, 笔试题目是: 随意编写两个对输入参数做加减乘除运算的函数(需要有除法),写完后,用装饰器实现对函数出现除数为0的异常捕获,如果有异常,使用print打印日志. ...
- shell从字符串中提取子串(正则表达式)
通过试验,可以通过grep.sed两种方式实现. 假设需要提取libgcc-4.8.5-4.h5.x86_64.rpm中的版本号. grep echo "libgcc-4.8.5-4.h5. ...
- iOS之CAReplicatorLayer属性简介和使用
1.CAReplicatorLayer简介 CAReplicatorLayer用于对图层进行复制,包括图层的动画也能复制!可以看着将某一段事务进行重复! #import <QuartzCore/ ...
- [c#源码分享]TCP通信中的大文件传送
NetworkComms网络通信框架序言 源码 (为节省空间,不包含通信框架源码,通信框架源码请另行下载) 文件传送在TCP通信中是经常用到的,本文针对文件传送进行探讨 经过测试,可以发送比较大的 ...
- python学习笔记:通配符之glob模块(过滤)
glob模块用来查找文件目录和文件,可以和常用的find功能进行类比.glob支持*?[]这三种通配符.返回的数据类型是list.常见的两个方法有glob.glob()和glob.iglob(),ig ...
- 元类,sqlalchemy查询
import sqlalchemy from sqlalchemy.ext.declarative import declarative_base #创建连接实例 db = sqlalchemy.cr ...
- python之命名元组的好处
collections.namedtuple() 命名元组的一个主要用途是将你的代码从下标操作中解脱出来举例使用 # 使用 from collections import namedtuple Sub ...
- 面试题: nodejs 的事件轮询机制
setTimeout(function(){ console.log('setTimeout()执行了') },0) setImmediate(function(){ console.log('set ...