真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Java虛擬機(jī)怎么利用JVM進(jìn)行優(yōu)化-創(chuàng)新互聯(lián)

本篇文章為大家展示了Java虛擬機(jī)怎么利用JVM進(jìn)行優(yōu)化,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

創(chuàng)新互聯(lián)建站 - 綿陽主機(jī)托管,四川服務(wù)器租用,成都服務(wù)器租用,四川網(wǎng)通托管,綿陽服務(wù)器托管,德陽服務(wù)器托管,遂寧服務(wù)器托管,綿陽服務(wù)器托管,四川云主機(jī),成都云主機(jī),西南云主機(jī),綿陽主機(jī)托管,西南服務(wù)器托管,四川/成都大帶寬,機(jī)柜大帶寬、租用·托管,四川老牌IDC服務(wù)商

前言

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

Java虛擬機(jī)怎么利用JVM進(jìn)行優(yōu)化

jcmd看VM參數(shù)(第一次使用這個(gè)命令)

jcmd pid VM.flags

Java虛擬機(jī)怎么利用JVM進(jìn)行優(yōu)化

可以看到Y(jié)GC了8W多次,F(xiàn)GC有1100+,相比較另一個(gè)發(fā)出來求教的,我這個(gè)更糟糕,他的是運(yùn)行了3天左右 FGC370次

然后飛神讓我看下運(yùn)行時(shí)間

ps -p pid -o etime

Java虛擬機(jī)怎么利用JVM進(jìn)行優(yōu)化

我的也是跑了3天左右,感覺優(yōu)化空間非常的大

又讓我拉了JVM配置

jinfo -flags pid(沒權(quán)限,沒執(zhí)行成功)

ps aux | grep pid

Java虛擬機(jī)怎么利用JVM進(jìn)行優(yōu)化

發(fā)現(xiàn)我的JVM完全沒做過優(yōu)化,據(jù)我自己的印象,就改過PermSize,因?yàn)檫@個(gè)OOM過,所以調(diào)大了一點(diǎn)。

axPermSize=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

Java虛擬機(jī)怎么利用JVM進(jìn)行優(yōu)化

由于沒有開啟GC日志,于是笨神讓我開著jstat(飛神提到jstat -gccause pid可以gc情況),然后在另一個(gè)窗口執(zhí)行jmap -histo:live

剛開始沒明白,后來才知道原來這個(gè)命令可以觸發(fā)FGC

Java虛擬機(jī)怎么利用JVM進(jìn)行優(yōu)化

可以看到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

上述內(nèi)容就是Java虛擬機(jī)怎么利用JVM進(jìn)行優(yōu)化,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


文章標(biāo)題:Java虛擬機(jī)怎么利用JVM進(jìn)行優(yōu)化-創(chuàng)新互聯(lián)
網(wǎng)站URL:http://weahome.cn/article/geioi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部