当前位置:首页 > 每日看点 > 正文内容

jvm调优有什么技巧?

卡卷网12个月前 (01-11)每日看点190

场景一、CPU过高

CPU占用过高排查思路:(查进程->查线程列表->查线程堆栈)

step1:通过top命令查询占用CPU情况</>

//top

//p.s.shift+p(大写的P-cpu排序)shift+m(大写的M-内存排序)

step2:通过进程pid,查询对应的线程列表</>

//top-Hppid

    -H:显示线程信息-ppid1,pid2,...:只显示指定进程的信息

step3:线程id转为十六进制</>

从step2中可以看到占用cpu较高的线程id,打印出十六进制

//printf'%x\n'id

step4:通过jstack查出线程栈信息</>

cpu过高主要是线程方面的问题,我们知道jvm中每个线程都分配了单的栈,我们可以通过jstack查看线程栈情况。

//jstackpid

p.s.这里的pid为进程id,也就是第一步top中的pid

对照着step3中占用cpu最高的线程十六进制值可以定位到线程的栈信息。

上图可以看到具体定位到了ja的代码,就可以具体分析一下这个ja代码为什么会创建大量的线程占用大量的cpu。

除了ja程序线程问题,cpu过高也可能是线程死锁造成的,我们通过jstack也可以查看线程死锁的情况。

step5:通过jstack查看情况死锁情况</>

//jstack-lpid

-l:除了线程列表外,还显示关于锁的附加信息

通过栈中的信息可以定位到代码中死锁的代码。

step6:通过jstat查看gc情况</>

除了以上的各种情况,还有一种就是ja频繁的gc也会造成cpu占用过高

//jstat-gcutilpid1000

//1000ms为刷新数据的间隔时间

如果有频繁的gc就可以分析堆数据中哪些对象创建的较多,就可以具体分析了。

场景二、内存占用过高

排查思路:(查进程->jvm内存占用)

step1:通过top命令查询占用CPU情况

top

p.s.shift+p(大写的P-cpu排序)shift+m(大写的M-内存排序)

step2:通过进程pid查看gc情况

jstat-gcutilpid1000

以下是该命令的输出结果说明:

    S0:表示svivorspace0区域的使用情况,即第1个幸存区的使用情况。S1:表示svivorspace1区域的使用情况,即第2个幸存区的使用情况。E:表示edenspace区域的使用情况,即新生代中Eden区的使用情况。O:表示oldspace区域的使用情况,即老年代中的使用情况。M:表示metaspace区域的使用情况,即元空间中的使用情况。C:表示压缩类空间的使用情况。如果JVM启用了类数据共享(CDS)技术并且开启了压缩类指针(CompressedClassPointer)选项,那么就会存在一个称为“压缩类空间”的特殊区域,用于存放共享的类元数据信息。YGC:表示年轻代回收的次数。年轻代是JVM中内存分配的主要区域,回收在此区域较为频繁。YGCT:表示年轻代回收所花费的时间总和。通常情况下,年轻代回收所需时间不应过长,否则可能会导致响应变慢或出现卡顿现象。FGC:表示FullGC(全局回收)的次数。FullGC是对整个Ja堆进行清理的回收过程,较为耗时。FGCT:表示FullGC所花费的时间总和。FullGC的执行时间通常年轻代回收要长得多,因为它需要处理整个Ja堆。GCT:表示所有回收所花费的时间总和,即YGCT和FGCT的总和。

以上各个区域的使用情况都会以百分的形式进行显示,即0.0%~100.0%之间。

例如,如果输出结果为“40.0020.0060.0070.00100.00”,则表示:

    //svivorspace0的使用率为40.00%svivorspace1的使用率为20.00%edenspace的使用率为60.00%oldspace的使用率为70.00%metaspace的使用率为100.00%

step3:通过jmap查看堆情况

通过step2已经发现jvm中的数据过多,频繁的ygc并且大量的数据都在老年代没有回收,这样就会表现出内存占用过高。下一步就是分析那些对象占用了内存。

//jmap-histopid

//jmap-histo命令可以用于输出Ja堆内存中各个对象类型及其数量的计信息。具体说明如下:

    num参数代表要分析的Ja进程中的对象编号instances:表示Ja堆内存中对象的数量ytes:表示Ja堆内存中对象占用的总字节数。classname:表示Ja堆内存中对象所属类名。

可以看到org.example.User创建的较多。这相就可以具体分析一下代码中哪些地方创建了User为什么没被回收。

与jmap-histo类似的命令:

#jmap-dump jmap-dump:format=,file=heapdump.hprofpid

//jmap-dump命令可以用于生成Ja进程的内存快照文件(.hprof格式),以便进行后续的分析和调试。具体说明如下:

    //filepath:表示生成的内存快照文件路径。该文件可以通过Ja虚拟机诊断工具(例如VisualVM、EclipseMemoryAnalyzer等)进行分析和调试。pid:表示要生成内存快照的Ja进程的进程ID。

导出的快照文件可以通过jvisualvm或mat来查看:

    //jvisualvm

    //mat

mat还较智能,直接把存在问题的给你列出来

step4:jmap-heapjvm内存实际占用情况

除了以上内存占用情况,在ja项目中还存在一种情况。如我ja项目没有配置jvm参数都使用默认的配置,我64G内存。会发现用一段时间后ja进程占用了8G内存。这时你可以使用命令看看ja实际使用的内存情况,然后再调整jvm参数。

jmap-heap是一个用于获取Ja堆内存信息的命令行工具,它可以输出Ja虚拟机中堆内存的使用情况和配置信息。

玄明Hanko:深度剖析JVM调优法则:从两大特性CPU、内存出发轻松掌握调优实战技巧玄明Hanko:JVM调优神器,运用Arthas释放Ja应用性能的全部潜力

扫描二维码推送至手机访问。

版权声明:本文由卡卷网发布,如需转载请注明出处。

本文链接:https://www.kajuan.net/ttnews/2025/01/8733.html

分享给朋友:

相关文章

每天5点就下班了,闲着也是闲着,有哪些副业可以推荐?

每天5点就下班了,闲着也是闲着,有哪些副业可以推荐?

今天整理了36个搞钱APP可以先接触学习看看,然后选定一个感兴趣的方向去精进要知道机会不是一下子来临的,而一定是你前期做了很多准备每天进步一点点,就像滚雪球一样希望所以女生,能够在2024年提升自己,立下一个新的搞钱Flag吧实用APP安利...

手机用久了,垃圾都在哪里,总是内存显示不够,还很卡,这可怎么解决?

手机用久了,垃圾都在哪里,总是内存显示不够,还很卡,这可怎么解决?

大家的手机在使用一段时间之后啊,是不是都会出现又卡又慢的情况,尤其是安卓手机,这种现象更是非常明显,而且很多朋友啊,也都知道手机之所以会出现这些问题,一般都是手机安装了大量软件,而这些软件在使用过程中会产生大量的缓存垃圾,因此啊时间久了就会...

天涯论坛关闭后,除了知乎,大家都在逛什么?

天涯论坛关闭后,除了知乎,大家都在逛什么?

天涯神贴合集完整版,给大家整理好了!那年大学,打开天涯,感觉打开了一片新天地,里面什么样的人都有,有大神也有蛇神,比某乎好太多了,可惜后面关了很多年前,天涯社区曾出现了不少深受欢迎的帖子,成功地预言了许多形势和事件。这些帖子因此被冠以“天涯...

你捡过最大的漏是什么?

你捡过最大的漏是什么?

买了套二手房,软磨硬泡便宜了1个w 结果就是一屋子狼藉 原业主说反正你们要重新装修 就不收拾了 等完了你们一起收拾掉吧 落了很多柜子 电器是啥的 今天打开卧室柜子一看…现在是去存钱的路上有朋友知道这样存钱银行会给发大米跟油吗...

有哪些让你目瞪口呆的 Bug ?

有哪些让你目瞪口呆的 Bug ?

成都有个监狱情况比较特殊,关押的基本全是重犯,而且还都是经济犯和政治犯,他们以前都是一方大佬,在自己的一亩三分地翻手为云覆手为雨,无非是不小心中箭落马或帮老大顶锅才进监狱,所以即使进来了,他们依然保持着体面和骄傲,依从性差,虽然不至于和监狱...

阿里云服务器续费价格好贵,想换一家云服务厂商,该怎么选择?

阿里云服务器续费价格好贵,想换一家云服务厂商,该怎么选择?

最近一台买了3年时间的腾讯云轻量服务器到期了,还有5天时间。当时买的价格是3年198元。配置是2核CPU、4GB内存,80GB SSD云硬盘,1200GB 流量包,然后中途给免费升级了CPU,从2核变成了4核。平均下来一年的费用70元不到,...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。