虚拟机性能监控与故障处理工具

虚拟机性能监控与故障处理工具

jdk1.5的虚拟机,程序启动时请添加参数“-Dcom.sun.management.jmxremote”开启JMX管理功能

1 jps:虚拟机进程状况工具

功能:可以列出正在运行的虚拟机进程,并显示虚拟机执行主类(Main Class,main()函数所在的类)的名称,以及这些进程的本地虚拟机的唯一ID(LVMID)

本地虚拟机进程的LVMID,等于操作系统的进程ID;

使用Windows的任务管理器或Unix的ps命令也可以查询到虚拟机进程的LVMID,但如果同时启动了多个虚拟机进程,无法根据进程名称定位时,那就只能依赖jps命令显示主类的功能才能区分了

jps [options] [hostid] 如 jps -l 2388

jps可以通过RMI协议查询开启了RMI服务的远程虚拟机进程状态,hostid为RMI注册表中注册的主机名

options选项又q,m,l,v---------

2 jstat:虚拟机统计信息监视工具

功能:用于监视虚拟机各种运行状态信息的命令行工具。

它可以显示本地或远程[插图]虚拟机进程中的类装载、内存、垃圾收集、JIT编译等运行数据,在没有GUI图形界面,只提供了纯文本控制台环境的服务器上,它将是运行期定位虚拟机性能问题的首选工具

jstat [option vmid [interval[s|ms] [count] ] ]

命令格式中的vmid,如果是本地虚拟机,通lvmid一致,如果是远程虚拟机,vmid为

[protocol:] [//] lvmid [@hostname[:port]/servername]

interval查询间隔,默认毫秒,count查询次数,默认为1;

option代表查询的虚拟机信息,分为类装载、垃圾收集和运行期编译状况


3 jinfo:Java配置信息工具

功能:实时地查看和调整虚拟机的各项参数

-v参数可以查看虚拟机启动时显式指定的参数列表

-flag选项进行查询未被显式指定的参数的系统默认值(jdk1.6或使用java -XX:+PrintFlagsFinal)

-sysprops选项把虚拟机进程的System. getProperties()的内容打印出来

使用-flag [+|-]name或-flagname=value修改一部分运行期可写的虚拟机参数值

查询某参数值,可使用例如jinfo -flag CMSInitiatingOccupancyFraction 1444

4 jmap:Java内存映像工具

功能:用于生成堆转储快照(一般称为heapdump或dump文件)

还可以查询finalize执行队列,Java堆和永久代的详细信息,如空间使用率、当前用的是哪种收集器;

其他方法如使用-XX:HeapDumpOnOutOfMemoryError参数再发生oom时生成dump,-XX:HeapDumpOnCtrlBreak参数则可以使用[Ctrl]+[Break]生成,或Linux系统下通过Kill-3命令生成

windows下可以使用-dump,-histo(查看每个类的实例、空间占用统计),其他都只能再Linux使用

5 jhat:虚拟机堆转储快照分析工具

功能:分析jmap生成的堆转储快照(被VisualVM,以及专业用于分析dump文件的EclipseMemory Analyzer、IBM HeapAnalyzer替代)

内置了http/hhtml服务器,可以将生成的dump在浏览器打开;由于性能分析耗时以及分析简陋一般不使用;

分析结果默认以包为单位进行分组显示,分析内存泄漏问题主要会使用到其中的“Heap Histogram”与OQL页签的功能,前者可以找到内存中总容量最大的对象,后者是标准的对象查询语言

6 jstack:Java堆栈跟踪工具

功能:用于生成虚拟机当前时刻的线程快照(一般称为threaddump或javacore文件)

生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待,可以知道没有响应的线程到底在后台做些什么事情,或者等待着什么资源

java.lang.Thread类新增了一个getAllStackTraces()方法用于获取虚拟机中所有线程的StackTraceElement对象,可以完成jstack的大部分功能,使用中可以用这个方法做管理员界面;

代码清单4-5 查看线程状况的JSP页面

4.3 JDK的可视化工具(JConsole 1.5 VisualVM 1.6)

1 JConsole:Java监视与管理控制台

一款基于JMX的可视化监视和管理的工具

管理部分的功能是针对JMX MBean进行管理,由于MBean可以使用代码、中间件服务器的管理控制台或者所有符合JMX规范的软件进行访问,所以一下介绍的时监视功能

启动:双击jconsole.exe

主界面里共包括“概述”、“内存”、“线程”、“类”、“VM摘要”和“MBean”六个页签

2 VisualVM:多合一故障处理工具(jdk1.6 update7出现,可向下兼容)

随JDK发布的功能最强大的运行监视和故障处理程序

除了运行监视、故障处理外,如性能分析(Profiling),VisualVM的性能分析功能甚至比起JProfiler、YourKit等专业且收费的Profiling工具都不会逊色多少,而且VisualVM的还有一个很大优点:不需要被监视的程序基于特殊Agent运行,因此它对应用程序的实际性能的影响很小,使得它可以直接应用在生产环境中

□ 显示虚拟机进程及进程的配置和环境信息(jps、jinfo)。□ 监视应用程序的CPU、GC、堆、方法区及线程的信息(jstat、jstack)。□ dump及分析堆转储快照(jmap、jhat)。□ 方法级的程序运行性能分析,找出被调用最多、运行时间最长的方法。□ 离线程序快照:收集程序的运行时配置、线程dump、内存dump等信息建立一个快照,可以将快照发送开发者处进行Bug反馈。□ 其他plugins的无限的可能性……

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值