Java虛擬機(jī)JVM優(yōu)化實(shí)戰(zhàn)的過程全記錄
前言
Java虛擬機(jī)是運(yùn)行所有Java程序的抽象計(jì)算機(jī),是Java語言的運(yùn)行環(huán)境,它是Java 最具吸引力的特性之一。Java虛擬機(jī)是通過在實(shí)際的計(jì)算機(jī)上仿真模擬各種計(jì)算機(jī)功能模擬來實(shí)現(xiàn)的,通過Java虛擬機(jī),您只要根據(jù)JVM規(guī)格描述將解釋器移植到特定的計(jì)算機(jī)上,就能保證經(jīng)過編譯的任何Java代碼能夠在該系統(tǒng)上運(yùn)行。
最近在看JVM群里有人發(fā)了一個(gè)GC情況,讓人幫忙看優(yōu)化的,于是我也湊熱鬧發(fā)了出來想讓群里的大神們指導(dǎo)優(yōu)化一下,以下是優(yōu)化過程記錄.
一開始我貼了下面的兩張圖
jstat看GC記錄
jstat -gcutil pid 1000 20
jcmd看VM參數(shù)(第一次使用這個(gè)命令)
jcmd pid VM.flags
可以看到Y(jié)GC了8W多次,F(xiàn)GC有1100+,相比較另一個(gè)發(fā)出來求教的,我這個(gè)更糟糕,他的是運(yùn)行了3天左右 FGC370次
然后飛神讓我看下運(yùn)行時(shí)間
ps -p pid -o etime
我的也是跑了3天左右,感覺優(yōu)化空間非常的大
又讓我拉了JVM配置
jinfo -flags pid
(沒權(quán)限,沒執(zhí)行成功)
ps aux | grep pid
發(fā)現(xiàn)我的JVM完全沒做過優(yōu)化,據(jù)我自己的印象,就改過PermSize,因?yàn)檫@個(gè)OOM過,所以調(diào)大了一點(diǎn)。
然后飛神給了我一份他之前用過的配置
JAVA_OPTS="-Xms2g -Xmx2g -Xmn512m -XX:MaxPermSize=256m -server -Xss256k -XX:PermSize=128M -XX:+PrintGCDetails -XX:+PrintGCDateStamps -Xloggc:/data/log/gclog/gc.log -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/data/log/jvmdump/jvm.bin -XX:+UseConcMarkSweepGC -XX:+UseParNewGC -XX:CMSInitiatingOccupancyFraction=75 -XX:+UseCMSInitiatingOccupancyOnly -XX:+UseCMSCompactAtFullCollection -XX:CMSFullGCsBeforeCompaction=0 -XX:+CMSClassUnloadingEnabled -XX:+TieredCompilation -XX:+PrintTenuringDistribution -XX:+PrintGCApplicationStoppedTime -XX:+PrintHeapAtGC
并囑咐了一句loggc和dumpPath提前mkdir
因?yàn)橐呀?jīng)是周五晚上了,我沒有權(quán)限直接修改這個(gè)配置,所以準(zhǔn)備下周一再配上去看效果。
萬萬沒想到,回家路上,笨神出來說話了,要我看下存活實(shí)例
jmap -histo:live pid
由于沒有開啟GC日志,于是笨神讓我開著jstat(飛神提到jstat -gccause pid
可以gc情況),然后在另一個(gè)窗口執(zhí)行jmap -histo:live
剛開始沒明白,后來才知道原來這個(gè)命令可以觸發(fā)FGC
可以看到FGC了以后Old區(qū)從90%降到了79%,F(xiàn)GC效果很差,說明活對(duì)象太多了。
回過頭去看jmap實(shí)例,發(fā)現(xiàn)AtomicInteger這個(gè)類對(duì)象特別的多,竟然有300多萬個(gè)實(shí)例,已經(jīng)是top2了。
翻看代碼沒有發(fā)現(xiàn)有使用這個(gè)類的地方,初步懷疑是依賴的jar包使用的,笨神建議dump用MAT分析一下。
dump命令導(dǎo)出文件
jmap -dump:format=b,file=pid.dump pid
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,暫時(shí)告一段落,持續(xù)更新中。希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
ServletContext讀取web資源_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了ServletContext讀取web資源,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07解決feignclient調(diào)用服務(wù),傳遞的中文數(shù)據(jù)成???問題
這篇文章主要介紹了解決feignclient調(diào)用服務(wù),傳遞的中文數(shù)據(jù)成???問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01KafkaListener注解的實(shí)現(xiàn)機(jī)制源碼解析
這篇文章主要為大家介紹了KafkaListener注解的實(shí)現(xiàn)機(jī)制源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10手把手帶你掌握SpringBoot RabbitMQ延遲隊(duì)列
RabbitMQ 是一個(gè)由Erlang語言開發(fā)的AMQP的開源實(shí)現(xiàn),支持多種客戶端。用于在分布式系統(tǒng)中存儲(chǔ)轉(zhuǎn)發(fā)消息,在易用性、擴(kuò)展性、高可用性等方面表現(xiàn)不俗,下文將帶你深入了解 RabbitMQ 延遲隊(duì)列2021-09-09Java基礎(chǔ)教程之理解Annotation詳細(xì)介紹
這篇文章主要介紹了Java基礎(chǔ)教程之理解Annotation詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2017-01-01Java的設(shè)計(jì)模式編程中迪米特法則的應(yīng)用示例
這篇文章主要介紹了Java的設(shè)計(jì)模式編程中迪米特法則的應(yīng)用示例,迪米特法則中主張創(chuàng)建和使用弱耦合的類,需要的朋友可以參考下2016-02-02Mybatis注解開發(fā)單表、多表操作的實(shí)現(xiàn)代碼
這篇文章主要介紹了Mybatis高級(jí):Mybatis注解開發(fā)單表操作,Mybatis注解開發(fā)多表操作,構(gòu)建sql語句,綜合案例學(xué)生管理系統(tǒng)使用接口注解方式優(yōu)化,需要的朋友可以參考下2021-02-02