国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - Java虛擬機(jī)JVM優(yōu)化實戰(zhàn)的過程全記錄

Java虛擬機(jī)JVM優(yōu)化實戰(zhàn)的過程全記錄

2020-12-11 15:24MartinDai Java教程

有人說Java之所以能夠崛起,JVM功不可沒。Java虛擬機(jī)最初服務(wù)于讓Java語言凌駕于平臺之上,實現(xiàn)“編寫一次,到處運行”,那么下面這篇文章主要給大家分享了個關(guān)于Java虛擬機(jī)JVM優(yōu)化實戰(zhàn)的過程全記錄,需要的朋友可以參考借鑒,

前言

java虛擬機(jī)是運行所有java程序的抽象計算機(jī),是java語言的運行環(huán)境,它是java 最具吸引力的特性之一。java虛擬機(jī)是通過在實際的計算機(jī)上仿真模擬各種計算機(jī)功能模擬來實現(xiàn)的,通過java虛擬機(jī),您只要根據(jù)jvm規(guī)格描述將解釋器移植到特定的計算機(jī)上,就能保證經(jīng)過編譯的任何java代碼能夠在該系統(tǒng)上運行。

最近在看jvm群里有人發(fā)了一個gc情況,讓人幫忙看優(yōu)化的,于是我也湊熱鬧發(fā)了出來想讓群里的大神們指導(dǎo)優(yōu)化一下,以下是優(yōu)化過程記錄.

一開始我貼了下面的兩張圖

jstat看gc記錄

jstat -gcutil pid 1000 20

Java虛擬機(jī)JVM優(yōu)化實戰(zhàn)的過程全記錄

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

jcmd pid vm.flags

Java虛擬機(jī)JVM優(yōu)化實戰(zhàn)的過程全記錄

可以看到y(tǒng)gc了8w多次,fgc有1100+,相比較另一個發(fā)出來求教的,我這個更糟糕,他的是運行了3天左右 fgc370次

然后飛神讓我看下運行時間

ps -p pid -o etime

Java虛擬機(jī)JVM優(yōu)化實戰(zhàn)的過程全記錄

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

又讓我拉了jvm配置

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

ps aux | grep pid

Java虛擬機(jī)JVM優(yōu)化實戰(zhàn)的過程全記錄

發(fā)現(xiàn)我的jvm完全沒做過優(yōu)化,據(jù)我自己的印象,就改過permsize,因為這個oom過,所以調(diào)大了一點。

然后飛神給了我一份他之前用過的配置

?
1
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

因為已經(jīng)是周五晚上了,我沒有權(quán)限直接修改這個配置,所以準(zhǔn)備下周一再配上去看效果。

萬萬沒想到,回家路上,笨神出來說話了,要我看下存活實例

jmap -histo:live pid

Java虛擬機(jī)JVM優(yōu)化實戰(zhàn)的過程全記錄

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

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

Java虛擬機(jī)JVM優(yōu)化實戰(zhàn)的過程全記錄

可以看到fgc了以后old區(qū)從90%降到了79%,fgc效果很差,說明活對象太多了。

回過頭去看jmap實例,發(fā)現(xiàn)atomicinteger這個類對象特別的多,竟然有300多萬個實例,已經(jīng)是top2了。

翻看代碼沒有發(fā)現(xiàn)有使用這個類的地方,初步懷疑是依賴的jar包使用的,笨神建議dump用mat分析一下。

dump命令導(dǎo)出文件

jmap -dump:format=b,file=pid.dump pid

總結(jié)

以上就是這篇文章的全部內(nèi)容了,暫時告一段落,持續(xù)更新中。希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對服務(wù)器之家的支持。

原文鏈接:https://segmentfault.com/a/1190000010510968

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产一区二区三区四区五区密私 | 操操操av | 黄色电影天堂 | 亚洲a网| 国产精品美女久久久久久久久久久 | 日韩视频三区 | 高清hd写真福利在线播放 | 精品福利视频网站 | 成人免费观看视频 | 在线看的av | 国产精品久久久久永久免费观看 | 天堂va蜜桃一区二区三区漫画版 | 国产成人黄色 | 色婷婷av一区二区三区大白胸 | 国产成人免费视频网站视频社区 | 影音在线资源 | 天天爽夜夜爽夜夜爽精品视频 | 欧美午夜一区二区福利视频 | 国产特级毛片aaaaaa毛片 | 日韩中文字幕视频在线观看 | 日韩手机在线观看 | 激情久久综合网 | 欧美一级免费高清 | 精品国产青草久久久久福利 | 久久精品国产一区二区三区 | 亚洲综合中文 | 日韩在线综合 | 红桃视频一区二区三区免费 | 九九热精品在线 | 日韩欧美一区二区三区免费观看 | 91久久国产精品 | 一区二区日本 | 亚洲精品电影在线观看 | 亚洲精品系列 | 久久久久久久av | 色之久久综合 | 自拍偷拍视频网站 | 在线观看日韩精品 | 成人av观看| 成人网av | 国产一区二区三区免费播放 |