深入理解java虚拟机读书笔记,第四章:虚拟机性能监控与故障处理

4.1概述

定位问题,知识、经验是关键基础,数据是依据,工具是运用知识处理数据的手段

数据包含:运行日志、异常堆栈、GC日志、线程快照(threaddump/javacore文件)、堆转储快照(heapdump/hprof文件)


jdk的bin路径下用于监视虚拟机和故障处理的工具

工具都特别小,是jdk/lib/tools.jar的包装

借助tools.jar接口,在程序中实现强大的监控分析功能


4.2JDK命令行工具

4.2.1jps(JVM process status tool)

虚拟机进程状况工具

列出虚拟机进程、显示虚拟机执行主类名称、这些进程的本地虚拟机唯一ID(local virtual machine identifier)

对于本地虚拟机,LVMID和进程ID(Process identifier,PID)一致

如果同时启动多个虚拟机,无法根据进程名称定位,就需要依赖jps的查看主类的功能才能区分


工具选项说明

q:只显示LVMID,省略主类的名称

m:输出虚拟机启动时传递给主类main()函数的参数

l:输出主类的全名,如果进程执行的是jar包,输出jar路径

v:输出虚拟机进程启动时JVM参数

4.2.2jstat(JVM statistics monitoring tool)

虚拟机统计信息监视工具

用于监视虚拟机各种运行状态信息

显示本地或远程虚拟机进程中类装载、内存、垃圾收集、JIT编译的动态数据

对于本地虚拟机进程,VMID和LVMID一致

对于远程虚拟机,VMID格式为[protocol:][//] lvmid [@hostname:[port]/servername]

interval和count代表运行的间隔和次数

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


工具选项说明

-class:监视类装载、卸载数量、总空间以及类装载耗费的时间

-gc:监视java堆状况,包含Eden区、两个survivor区、老年代、永久带的容量、已用空间、GC时间合计信息等

-gccapacity:监视内容和-gc基本相同,输出主要关注各个区域使用到的最大、最小空间

-gcutil:监视内容和-gc基本相同,输出主要关注已用空间的占比

-gccause:和gcutil一样,会额外输出导致上一次gc的原因

-gcnew:监视新生代gc状况

-gcnewcapacity:和-gcnew基本相同,主要关注使用到的最大、最小空间

-gcold:监视老年代gc状况

-gcoldcapacity:和-gcold基本相同,主要关注使用到的最大、最小空间

-gcpermcapacity:输出永久代使用的最大、最小空间

-compiler:输出JIT编译器编译过的方法、耗时等信息

-printcompilation:输出已经被JIT编译过的方法

4.2.3jinfo(Configuration info for java)

java配置信息工具

实时的查看和调整虚拟机参数

查看虚拟机启动时未被显式指定的系统默认值,用jinfo的-flag

4.2.4jmap(Memory map for java)

Java内存映像工具

生成堆转储快照(一般称为heapdump或dump文件)

查询finalize执行队列

java堆和永久代的详细信息,如空间使用率、当前用的哪种收集器

工具选项说明

4.2.5jhat(JVM heap analysis Tool)

java堆转储快照分析工具

jhat内置微型http/html服务器,生成dump文件的分析结果后,可以在浏览器查看

一般不会直接用jhat命令分析dump

一般不会直接在部署的服务器上直接分析dump文件,分析耗时、消耗硬件资源

分析功能比较简陋

一般用virtualVM、Eclipse Memory analyzer、IBM HeapAnalyzer

4.2.6jstack(Stack Trace for java)

java堆栈跟踪工具

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

线程快照就是每一个线程执行的方法堆栈的集合

定位线程长时间停顿的原因,如线程死锁、死循环、请求外部资源导致的长时间等待

工具选项说明

4.2.7hsdis:JIT生成代码反汇编

作用是让Hotspot的-XX:printAssembly指令调用它来把动态生成的的本地代码还原为汇编代码输出,同时生成大量有价值的注释

4.3JDK的可视化工具

4.3.1Jconsole:java监视与管理控制台

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

管理部分的功能是针对JMX Mbean进行管理

Mbean可以通过代码、中间服务器的管理控制台、或所有符合JMX规范的软件访问


监视

1启动:JDK/bin下的jconsole.exe,自动搜索虚拟机进程,不需要jps来查询

2.内存监控:相当于可视化的jstat,用于监视受收集器管理的虚拟机内存(Java堆和永久代)的变化趋势

3线程监控:相当于可视化的jstack,查看线程停顿的原因,例如等待外部资源、死循环、锁等待

4.3.2:virtualVM:多合一故障处理

All-in-one java troubleshooting tool

运行监视、故障处理、性能分析

兼容范围与插件安装


通过插件扩展,virtualVM可以做到功能

显示虚拟机的进程以及进程配置、环境信息(jps、jinfo)

监视应用程序的CPU、GC、堆、方法区以及线程的信息(jstat、jstack)

dump以及分析堆转储快照(jmap、jhat)

方法级的程序运行性能分析,找出调用最多、运行时间最长的方法

离线程序快照,收集程序运行时配置、线程dump、内存dump等信息建立一个快照

其他plugin无限可能性...

生成、浏览堆转储快照

分析程序性能

做profiling分析对程序性能影响较大,在生产环境一般不会用这些功能

BTrace动态日志跟踪

在不停止目标程序的前提下,通过Hotspot虚拟机的HotSwap技术动态加入原本并不存在的调试代码

HotSwap技术:代码热替换技术,HotSpot虚拟机允许在不停止运行的情况下,更新已经加载的类的代码




参考文献:

[1] 深入理解Java虚拟机 第二版 --周志明


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • 一. jps : 虚拟机进程状况工具 功能:列出正在运行的虚拟机进程,并显示虚拟机执行主类(Main Class,...
    烟雨_任平生阅读 530评论 0 0
  • 美狄亚是古希腊悲剧作家欧里庇得斯的剧作《美狄亚》的主人公,是世界上第一部表现妇女悲剧的作品。作为科尔喀斯国王埃厄忒...
    周子岚阅读 1,087评论 0 2
  • 生活现实而残酷,能将一个人改变的面目全非。 前日,跟一个很久未见的朋友吃饭,聊天叙旧,恍惚间,感觉彼此隔着很远。 ...
    梨落2016阅读 281评论 0 0
  • 《查理九世》的第二本是《恐怖的巫女面具》。我花了一天的时间把这一本读完了。 书中多多把林警察当成了林巫女,因为她和...
    Jackie_牛阅读 594评论 0 2