作者:光陆光陆光陆 | 来源:互联网 | 2023-05-17 20:53
XPocket是PerfMa开源的为终结性能问题而生的插件容器,它将定位或者解决各种性能问题的常见的Linux命令,JDK工具,出名性能工具等适配成各种XPocket插件,并让它们能够互相联动,一键解决特定的性能问题。
你是否遇到过这些问题?
- 零碎存在性能问题
- 问题排查时一头雾水,不晓得用什么工具
- 查找工具,下载和装置都很浪费时间
- 排查问题非常繁琐,想尽量简化排查计划以供后续应用
XPocket是PerfMa开源的为终结性能问题而生的插件容器,它将定位或者解决各种性能问题的常见的Linux命令,JDK工具,出名性能工具等适配成各种XPocket插件,并让它们能够互相联动,一键解决特定的性能问题。
目前XPocket插件生态曾经实现了HSDB、JDB、JConsole、Perf、Arthas等多个优良的开源性能工具的插件化集成。XPocket反对JDK 8+,反对Linux/Mac/Windows,采纳命令行交互模式,提供丰盛的 Tab 主动补全性能,反对管道操作。
以下是XPocket官网提供的局部插件使用指南及实在案例。
1.XPocket插件jstack_x助力线程问题排查
https://heapdump.cn/article/2…
在程序开发过程中,开发人员通常会遇到许多线上问题,这些问题可能是代码Bug导致的,也可能是性能问题引起的。这些线上问题都会通过CPU飙升、GC频繁、抛出OOM异样等状况体现进去,这些问题的根因很可能是因为线程或线程池使用不当造成的。为了尽快定位根因,能够应用jstack_x插件以线程为切入点进行排查。
XPocket插件jstack_x在JDK自带的jstack工具上进行了加强,除了反对java栈和本地栈的输入外,还能够从锁的角度查看期待或持有锁的线程,另外还能够通过线程名称和nid过滤出特定的线程。
本文应用jstack_x插件别离排查了线程的CPU使用率飙升、无心中创立了超量的线程以及大量线程期待获取共享资源的问题,XPocket的jstack_x插件在JDK原有的jstack工具上做了加强,可能帮忙每个开发者更加疾速地排查定位出线程相干的问题。
jstack_x插件下载地址
https://plugin.xpocket.perfma…
XPocket下载地址
https://xpocket.perfma.com/do…
2.应用XPocket插件JConsole排查线上OOM异样案例
https://heapdump.cn/article/2…
XPocket插件JConsole次要用于内存问题的排查,可能对堆中的Eden、Survivor、Old区以及堆外的Metaspace、Code Cache等区域进行察看。
本文应用JConsole插件排查了频繁类加载引起OOM异样以及堆内存透露引起OOM异样的问题,JConsole可能排查Java过程内存的应用状况,特地是在排查过程中要进行屡次打印,比对数值来发现问题。如果要进一步在代码级别定位问题,还能够应用XPocket中的其它插件进行辅助定位。
JConsole插件下载地址
https://plugin.xpocket.perfma…
3.应用Perf插件跟踪过程切换信息
https://heapdump.cn/article/2…
CPU使用率是最直观和最罕用的零碎性能指标,是在排查性能问题时会关注的第一个指标。而在导致CPU使用率过高的因素中,过程切换问题也是十分常见的。过程上下文切换次数较多的状况下,很容易导致CPU 将大量工夫耗费在寄存器、内核栈、页表等资源的保留和复原上,以至于导致系统性能不能充分利用。
但过程切换次数过多或切换次数异样的时候,针对C/C++程序调式伎俩十分无限,很难找到过程切换的起因,Perf插件自身能够跟踪过程切换调用栈并进行统计,本文借助一个简略例子验证了此插件的性能。
在碰到零碎过程过程切换次数异样的问题时能够借助Perf插件,排查出具体函数。
Perf插件下载地址
https://plugin.xpocket.perfma…
4.应用Top_X插件排查内存过载问题
https://heapdump.cn/article/2…
Top命令是Linux 零碎下罕用的监控工具,用于实时获取过程级别的 CPU 或内存应用状况。
XPocket中的Top_X为Linux Top的增强版,能够显示CPU占用率/负载,CPU及内存过程应用的list。它对于繁冗的top命令输入进行了性能的拆分和整顿,更加清晰易用,反对管道化,尤其能够间接拿到top过程或线程tid,pid; mem_s命令减少了依照过程swap大小占用排序加强了原有top性能。
本文模仿一机器内存透露应用了大量物理内存导致物理内存飙升的状况。
在碰到内存过载问题时能够借助Top_X插件排查内存占用状况。
Top_X插件下载地址
https://plugin.xpocket.perfma…
5.应用VJMap排查频繁YGC问题
https://heapdump.cn/article/2…
分代版的jmap(新生代,存活区,老生代),是排查内存迟缓泄露,老生代增长过快起因的利器。因为jmap -histo PID 打印的是整个Heap的对象统计信息,而为了定位过程频繁YGC的问题,咱们须要专门查看OldGen对象,和Survivor区大龄对象的工具。
本文首先应用VJMap插件查看了频繁YGC过程的年老代的内存应用状况,而后联合HeapDump社区的XElephant工具进行dump文件剖析,最初排查出了问题所在。
VJMap插件下载地址
https://plugin.xpocket.perfma…
XPocket下载地址
https://xpocket.perfma.com/do…