在java代码中获取JVM参数(转)
近日关注性能调优,关注JMX,发现java.lang.management.*之强大。同时查阅了资料,整合一版关于JVM参数获取的note,仅供参考:
- MemoryMXBean memorymbean = ManagementFactory.getMemoryMXBean();
- MemoryUsage usage = memorymbean.getHeapMemoryUsage();
- System.out.println("INIT HEAP: " + usage.getInit());
- System.out.println("MAX HEAP: " + usage.getMax());
- System.out.println("USE HEAP: " + usage.getUsed());
- System.out.println("\nFull Information:");
- System.out.println("Heap Memory Usage: "
- + memorymbean.getHeapMemoryUsage());
- System.out.println("Non-Heap Memory Usage: "
- + memorymbean.getNonHeapMemoryUsage());
- List<String> inputArguments = ManagementFactory.getRuntimeMXBean().getInputArguments();
- System.out.println("===================java options=============== ");
- System.out.println(inputArguments);
- System.out.println("=======================通过java来获取相关系统状态============================ ");
- int i = (int)Runtime.getRuntime().totalMemory()/1024;//Java 虚拟机中的内存总量,以字节为单位
- System.out.println("总的内存量 i is "+i);
- int j = (int)Runtime.getRuntime().freeMemory()/1024;//Java 虚拟机中的空闲内存量
- System.out.println("空闲内存量 j is "+j);
- System.out.println("最大内存量 is "+Runtime.getRuntime().maxMemory()/1024);
- System.out.println("=======================OperatingSystemMXBean============================ ");
- OperatingSystemMXBean osm = (OperatingSystemMXBean) ManagementFactory.getOperatingSystemMXBean();
- // System.out.println(osm.getFreeSwapSpaceSize()/1024);
- // System.out.println(osm.getFreePhysicalMemorySize()/1024);
- // System.out.println(osm.getTotalPhysicalMemorySize()/1024);
- //获取操作系统相关信息
- System.out.println("osm.getArch() "+osm.getArch());
- System.out.println("osm.getAvailableProcessors() "+osm.getAvailableProcessors());
- //System.out.println("osm.getCommittedVirtualMemorySize() "+osm.getCommittedVirtualMemorySize());
- System.out.println("osm.getName() "+osm.getName());
- //System.out.println("osm.getProcessCpuTime() "+osm.getProcessCpuTime());
- System.out.println("osm.getVersion() "+osm.getVersion());
- //获取整个虚拟机内存使用情况
- System.out.println("=======================MemoryMXBean============================ ");
- MemoryMXBean mm=(MemoryMXBean)ManagementFactory.getMemoryMXBean();
- System.out.println("getHeapMemoryUsage "+mm.getHeapMemoryUsage());
- System.out.println("getNonHeapMemoryUsage "+mm.getNonHeapMemoryUsage());
- //获取各个线程的各种状态,CPU 占用情况,以及整个系统中的线程状况
- System.out.println("=======================ThreadMXBean============================ ");
- ThreadMXBean tm=(ThreadMXBean)ManagementFactory.getThreadMXBean();
- System.out.println("getThreadCount "+tm.getThreadCount());
- System.out.println("getPeakThreadCount "+tm.getPeakThreadCount());
- System.out.println("getCurrentThreadCpuTime "+tm.getCurrentThreadCpuTime());
- System.out.println("getDaemonThreadCount "+tm.getDaemonThreadCount());
- System.out.println("getCurrentThreadUserTime "+tm.getCurrentThreadUserTime());
- //当前编译器情况
- System.out.println("=======================CompilationMXBean============================ ");
- CompilationMXBean gm=(CompilationMXBean)ManagementFactory.getCompilationMXBean();
- System.out.println("getName "+gm.getName());
- System.out.println("getTotalCompilationTime "+gm.getTotalCompilationTime());
- //获取多个内存池的使用情况
- System.out.println("=======================MemoryPoolMXBean============================ ");
- List<MemoryPoolMXBean> mpmList=ManagementFactory.getMemoryPoolMXBeans();
- for(MemoryPoolMXBean mpm:mpmList){
- System.out.println("getUsage "+mpm.getUsage());
- System.out.println("getMemoryManagerNames "+mpm.getMemoryManagerNames().toString());
- }
- //获取GC的次数以及花费时间之类的信息
- System.out.println("=======================MemoryPoolMXBean============================ ");
- List<GarbageCollectorMXBean> gcmList=ManagementFactory.getGarbageCollectorMXBeans();
- for(GarbageCollectorMXBean gcm:gcmList){
- System.out.println("getName "+gcm.getName());
- System.out.println("getMemoryPoolNames "+gcm.getMemoryPoolNames());
- }
- //获取运行时信息
- System.out.println("=======================RuntimeMXBean============================ ");
- RuntimeMXBean rmb=(RuntimeMXBean)ManagementFactory.getRuntimeMXBean();
- System.out.println("getClassPath "+rmb.getClassPath());
- System.out.println("getLibraryPath "+rmb.getLibraryPath());
- System.out.println("getVmVersion "+rmb.getVmVersion());
运行结果如下:
- INIT HEAP: 268435456
- MAX HEAP: 1065484288
- USE HEAP: 331632
- Full Information:
- Heap Memory Usage: init = 268435456(262144K) used = 331632(323K) committed = 266403840(260160K) max = 1065484288(1040512K)
- Non-Heap Memory Usage: init = 134381568(131232K) used = 2607888(2546K) committed = 134709248(131552K) max = 570425344(557056K)
- ==========java options=====
- [-Xms256m, -Xmx1024m, -XX:PermSize=128M, -XX:MaxPermSize=512m, -Dfile.encoding=UTF-8]
- =======================通过java来获取相关系统状态============================
- 总的内存量 i is 260160
- 空闲内存量 j is 259836
- 最大内存量 is 1040512
- =======================OperatingSystemMXBean============================
- osm.getArch() x86
- osm.getAvailableProcessors() 2
- osm.getName() Windows 7
- osm.getVersion() 6.1
- =======================MemoryMXBean============================
- getHeapMemoryUsage init = 268435456(262144K) used = 331632(323K) committed = 266403840(260160K) max = 1065484288(1040512K)
- getNonHeapMemoryUsage init = 134381568(131232K) used = 2638064(2576K) committed = 134709248(131552K) max = 570425344(557056K)
- =======================ThreadMXBean============================
- getThreadCount 5
- getPeakThreadCount 5
- getCurrentThreadCpuTime 93600600
- getDaemonThreadCount 4
- getCurrentThreadUserTime 31200200
- =======================CompilationMXBean============================
- getName HotSpot Client Compiler
- getTotalCompilationTime 1
- =======================MemoryPoolMXBean============================
- getUsage init = 163840(160K) used = 473920(462K) committed = 491520(480K) max = 33554432(32768K)
- getMemoryManagerNames [Ljava.lang.String;@15b7986
- getUsage init = 16580608(16192K) used = 331632(323K) committed = 16580608(16192K) max = 66060288(64512K)
- getMemoryManagerNames [Ljava.lang.String;@1d9dc39
- getUsage init = 2031616(1984K) used = 0(0K) committed = 2031616(1984K) max = 8257536(8064K)
- getMemoryManagerNames [Ljava.lang.String;@93dcd
- getUsage init = 247791616(241984K) used = 0(0K) committed = 247791616(241984K) max = 991166464(967936K)
- getMemoryManagerNames [Ljava.lang.String;@b89838
- getUsage init = 134217728(131072K) used = 2213312(2161K) committed = 134217728(131072K) max = 536870912(524288K)
- getMemoryManagerNames [Ljava.lang.String;@111a3ac
- =======================MemoryPoolMXBean============================
- getName Copy
- getMemoryPoolNames [Ljava.lang.String;@110b053
- getName MarkSweepCompact
- getMemoryPoolNames [Ljava.lang.String;@a83b8a
- =======================RuntimeMXBean============================
- getClassPath E:\workspaces\mss-workspace\Jmx\bin;E:\workspaces\mss-workspace\Jmx\lib\jmxtools.jar
- getLibraryPath C:\Program Files (x86)\Java\jre6\bin;.;C:\Windows\Sun\Java\bin;C:\Windows\system32;C:\Windows;C:/Program Files (x86)/Java/jre6/bin/client;C:/Program Files (x86)/Java/jre6/bin;d:\oracle\product\10.2.0\client_2\bin;d:\oracle\product\10.2.0\client_1;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\v1.0\;C:\Program Files (x86)\ATI Technologies\ATI.ACE\Core-Static;C:\SWTOOLS\ReadyApps;C:\Program Files\TortoiseSVN\bin;C:\Program Files (x86)\Java\jdk1.6.0_14\bin;C:\Program Files (x86)\Java\jdk1.6.0_14\jre\bin;
- getVmVersion 14.0-b16
http://cn-done.iteye.com/blog/2041971
在java代码中获取JVM参数(转)的更多相关文章
- JAVA代码中获取JVM信息
一.JAVA中获取JVM的信息 原理,利用JavaSDK自带的ManagementFactory类来获取. 二.获取信息 1.获取进程ID @Test public void test1() { Ru ...
- java代码中获取进程process id(转)
另一方面,线程ID=进程ID+内部线程对象ID并不成立, 参考: blog.csdn.net/heyetina/article/details/6633901 如何在java代码中获取进 ...
- Java代码中获取Json的key值
测试json字符串: {"access_token":"hkbQl5o_l67dZ7_vJRATKBwTLk9Yj5QyMuOJThAr8Baj0xWf4wxW1p4ym ...
- Java代码中获取配置文件(config.properties)中内容的两种方法
方法千千万,本人暂时只总结了两种方法. (1)config.properties中的内容如图 在applicationContext.xml中配置 <!-- 引入配置文件 --> < ...
- java代码中获取classpath路径
Javaweb工程中,有时候需要自己手动的去读取classpath下面的配置文件,这里总结一点读取classpath路径的方法,分享一下. 方法一: String path = Test.class. ...
- Android开发之java代码中获取当前系统的时间工具类
/** * 获取当前时间 * * @return */ public String getTime() { Date date = new Date();// 创建一个时间对象,获取到当前的时间 Si ...
- 【转】使用JavaParser获得Java代码中的类名、方法形参列表中的参数名以及统计总的文件个数与不能解析的文件个数
遍历目录查找Java文件: public static void ergodicDir(File dir, HashSet<String> argNameSet, HashSet<S ...
- java如何从一段html代码中获取图片的src路径
java如何从一段html代码中获取图片的src路径 package com.cellstrain.icell.Test; import java.util.ArrayList;import java ...
- java高级用法之:在JNA中将本地方法映射到JAVA代码中
目录 简介 Library Mapping Function Mapping Invocation Mapping 防止VM崩溃 性能考虑 总结 简介 不管是JNI还是JNA,最终调用的都是nativ ...
随机推荐
- 在内网架设一个可供外网登录的ftpserver
ftpserver是使用比較寻常的server,可是IP资源是有限的.那么怎么让内网的server給外网的用户提供服务了? 首先须要找一个FTPserver程序,我在这边使用pure-ftpd-mys ...
- SVN基于Maven的Web项目更新,本地过程详细解释
周围环境 MyEclipse:10.7 Maven:3.1.1 概要 最近在做项目,MyEclipse下载SVN基于上述Maven的Web问题,有时候搞了非常半天,Maven项目还是出现叉号,最后总结 ...
- PHP实现栈(Stack)数据结构
栈(Stack),是一种特殊的后进先出线性表,其只能在一端进行插入(插入一般称为压栈.进栈或入栈)和删除(删除一般称为弹栈.退栈或出栈)操作,允许进行插入和删除操作的一端称为栈顶,另一端则称为栈底.栈 ...
- Rational Rose的四种视图介绍
Rose模型中有四种视图:Use Case View(用例视图),Logical View(逻辑视图),Component View(组建视图)和Deployment View(配置视图). 用例视图 ...
- malloc一次性最大能申请多大内存空间
受用户态内存地址空间的限制.64 位系统下分配几个 T 不成问题. 著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处.作者:zz matrix链接:http://www.zhihu. ...
- flex 错误信息类型及解决方法
总结一些经常出现的异常信息及处理方法(会一直持续更新): 异常1: 写actionscript3.0时遇到了错误.报错为:Error #2044: 未处理的 ioError:. text=Error ...
- Windows Phone开发(35):使用Express Blend绘图
原文:Windows Phone开发(35):使用Express Blend绘图 上一节中我们简单扯了一下绘图指令,然而那也不是最简单的绘图法,今天,我再向大家推荐一种更好的绘图方案--Express ...
- BZOJ 2002 HNOI2010 弹飞羊 块
标题效果,LCT解释版本:见 http://blog.csdn.net/popoqqq/article/details/38849471 如今,用一只手滑动块,并再次改写这个问题0.0 块短啊 将进入 ...
- proxy pattern 代理模式
常用的几种代理模式简要说明如下: (1) 远程代理(Remote Proxy):为一个位于不同的地址空间的对象提供一个本地的代理对象,这个不同的地址空间可以是在同一台主机中,也可是在另一台主机中,远 ...
- win7,win8取得管理员权限 .reg文件
Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\*\shell\runas] @="获取管理员所有权" " ...