bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

怎么在IntelliJIdea中對(duì)JVM的性能進(jìn)行調(diào)試-創(chuàng)新互聯(lián)

本篇文章為大家展示了怎么在IntelliJ Idea中對(duì)JVM的性能進(jìn)行調(diào)試,內(nèi)容簡明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站建設(shè)、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的東乃網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

調(diào)優(yōu)前的運(yùn)行狀態(tài)


 原始配置內(nèi)容

要查詢idea原始配置文件的路徑可以在VisualVM中的概述中查看

怎么在IntelliJ Idea中對(duì)JVM的性能進(jìn)行調(diào)試

原始配置內(nèi)容:

-XX:ReservedCodeCacheSize=240m
-XX:+UseCompressedOops
-Dfile.encoding=UTF-8
-XX:SoftRefLRUPolicyMSPerMB=50
-ea
-Dsun.io.useCanonCaches=false
-Djava.net.preferIPv4Stack=true
-Djdk.http.auth.tunneling.disabledSchemes=""
-XX:+HeapDumpOnOutOfMemoryError
-XX:-OmitStackTraceInFastThrow

-XX:ErrorFile=$USER_HOME/java_error_in_idea_%p.log
-XX:HeapDumpPath=$USER_HOME/java_error_in_idea.hprof

-Xmx512m

打印啟動(dòng)時(shí)間插件開發(fā)

需要直觀的看到優(yōu)化前和優(yōu)化后啟動(dòng)時(shí)間的變化,所以需要簡單做一個(gè)Idea的插件開發(fā),關(guān)于Idea插件開發(fā)的流程建議參考我以前的文章《IDEA插件:多線程文件下載插件開發(fā)》

JVM的啟動(dòng)時(shí)間到所有組件初始化完成后的時(shí)間就看做是IDEA的啟動(dòng)時(shí)間,代碼如下

public class MyApplicationInitializedListener implements ApplicationInitializedListener {
  @Override
  public void componentsInitialized() {
    RuntimeMXBean bean = ManagementFactory.getRuntimeMXBean();
    long startTime = bean.getStartTime();
    long costTime = System.currentTimeMillis() - startTime;

    Messages.showMessageDialog("毫秒:" + costTime, "啟動(dòng)耗時(shí)", Messages.getInformationIcon());
  }
}

plugin.xml中添加如下代碼:

<extensions defaultExtensionNs="com.intellij">
  <applicationInitializedListener id="MyApplicationInitializedListener"
                  implementation="cn.silently9527.MyApplicationInitializedListener"/>
</extensions>

優(yōu)化前的啟動(dòng)信息與時(shí)間消耗

怎么在IntelliJ Idea中對(duì)JVM的性能進(jìn)行調(diào)試怎么在IntelliJ Idea中對(duì)JVM的性能進(jìn)行調(diào)試

根據(jù)VisualGC和IDEA啟動(dòng)插件收集到的信息:

  • IDEA啟動(dòng)耗時(shí) 15s 總共垃圾收集22次,耗時(shí)1.2s,其中新生代GC 17次,耗時(shí)324ms;

  • 老年代GC 5次,耗時(shí)953ms 加載類27526個(gè),耗時(shí) 21s

按照這個(gè)數(shù)據(jù)來看也算是正常,15s 其實(shí)也在接受范圍內(nèi),由于本文主要演示性能調(diào)優(yōu),所以需要測試能否在快一些

開始嘗試優(yōu)化

調(diào)整內(nèi)存來控制垃圾回收頻率

圖上我們可以看出,啟動(dòng)參數(shù)指定的512m的內(nèi)存被分配到新生代的只有169m,由于IDEA是我們開發(fā)常用的工具,平時(shí)的編譯過程也需要足夠的內(nèi)存,所以我們需要先把總的內(nèi)存擴(kuò)大,這里我設(shè)置較大的內(nèi)存-Xmx1024m ,為了讓JVM在GC期間不需要再浪費(fèi)時(shí)間再動(dòng)態(tài)計(jì)算擴(kuò)容大小,同時(shí)也設(shè)置了-Xms1024m

在啟動(dòng)的過程中Eden共發(fā)生了17次GC,為了減少新生代gc次數(shù),我把新生代的內(nèi)存大小設(shè)置成-Xmn256m ;

重新啟動(dòng)之后查看VisualGC,新生代gc次數(shù)從 17次 降低到了 7次,耗時(shí)從 324ms 降低到了 152ms。

怎么在IntelliJ Idea中對(duì)JVM的性能進(jìn)行調(diào)試

在調(diào)整內(nèi)存前發(fā)生了5次Full GC,調(diào)整內(nèi)存后的依然還是有4次Full GC,但是從兩張圖我們可以看出,老年代的空間還有很多剩余,是不應(yīng)該發(fā)生Full GC的;考慮是否是代碼中有地方手動(dòng)調(diào)用System.gc() 出發(fā)了Full GC,所以添加了參數(shù)-XX:+DisableExplicitGC ,再次重新啟動(dòng)IDEA,結(jié)果很失望,依然還有4次Full GC;

再次仔細(xì)觀察優(yōu)化前的圖,注意看 Last Cause: Metadata GC Threshold , 最后一次gc是應(yīng)該Metaspace區(qū)域內(nèi)存不夠發(fā)生的GC,為了驗(yàn)證我們的猜想,打印出GC日志來看看。在idea.vmoptions 中添加打印日志相關(guān)的參數(shù):

-XX:+PrintGCDetails
-XX:+PrintGCDateStamps
-Xloggc:../gc.log

JVM的GC日志的主要參數(shù)包括如下幾個(gè):

  • -XX:+PrintGC 輸出GC日志

  • -XX:+PrintGCDetails 輸出GC的詳細(xì)日志

  • -XX:+PrintGCTimeStamps 輸出GC的時(shí)間戳(以基準(zhǔn)時(shí)間的形式)

  • -XX:+PrintGCDateStamps 輸出GC的時(shí)間戳(以日期的形式,如 2013-05-04T21:53:59.234+0800)

  • -XX:+PrintHeapAtGC 在進(jìn)行GC的前后打印出堆的信息

  • -Xloggc:../logs/gc.log 日志文件的輸出路徑

重新啟動(dòng)idea,查看gc.log

怎么在IntelliJ Idea中對(duì)JVM的性能進(jìn)行調(diào)試

其中PSYoungGen: 表示新生代使用的ParallelScavenge垃圾收集器,31416K->0K(181248K) 表示 gc前已使用的內(nèi)存大小 -> gc后已使用內(nèi)存大小(該區(qū)域的總內(nèi)存大小)

從日志中我們看出每次Full GC都是因?yàn)?code>Metadata GC Threshold ,而Metaspace每次gc回收的內(nèi)存幾乎沒有,僅僅是擴(kuò)大了該區(qū)域的容量;找到了原因那就好辦了,添加如下的參數(shù)調(diào)整Metaspace的大小:

-XX:MetaspaceSize=256m

再次重啟Idea之后,發(fā)現(xiàn)Full GC沒有了,心情很爽

怎么在IntelliJ Idea中對(duì)JVM的性能進(jìn)行調(diào)試

測試打開大項(xiàng)目點(diǎn)擊編譯代碼,發(fā)現(xiàn)自己的idea卡死了,查看VisualGC之后發(fā)現(xiàn)堆內(nèi)存都還有空閑,只有Metaspace被全部占滿了,所以是自己給的較大空間設(shè)置太小,所以直接去掉了-XX:MaxMetaspaceSize=256m

選擇垃圾收集器

從剛才的gc日志中,我們可以發(fā)現(xiàn)默認(rèn)使用的是ParallelScavenge + Parallel Old垃圾收集器,這個(gè)組合注重的是吞吐量,這里我們嘗試換一個(gè)注重低延時(shí)的垃圾收集器試一試

ParNew + CMS

idea.vmoptions 中添加如下配置:

-XX:+UseConcMarkSweepGC
-XX:+UseParNewGC

重啟IDEA之后查看VisualGC

怎么在IntelliJ Idea中對(duì)JVM的性能進(jìn)行調(diào)試

很尷尬,同樣發(fā)生了6次gc,ParallelScavenge + Parallel Old 的組合耗時(shí)197ms,而ParNew + CMS 的組合耗時(shí)379ms;雖然是這個(gè)結(jié)果,但是我們需要考慮當(dāng)前只發(fā)生了MinorGC,如果發(fā)生FullGC了結(jié)果又會(huì)如何了,大家可以自己測試一下

G1

我們?cè)趽Q一個(gè)新的G1垃圾回收器試試,在idea.vmoptions 中添加如下配置:

-XX:+UseG1GC

怎么在IntelliJ Idea中對(duì)JVM的性能進(jìn)行調(diào)試

這個(gè)結(jié)果好像也還是要慢一點(diǎn)點(diǎn),自己多次測試過這兩個(gè)垃圾回收器,雖然每次結(jié)果都不一樣,相差不遠(yuǎn),所以垃圾回收器可以自己選擇,這里我們選擇的是G1

類加載時(shí)間優(yōu)化

根據(jù)之前的分析,idea啟動(dòng)加載類27526個(gè),耗時(shí) 21s,這個(gè)我們有辦法能優(yōu)化一下嗎?因?yàn)閕dea是常用的開發(fā)工具,經(jīng)常很多人的使用,我們可以認(rèn)為它的代碼是安全的,是否符合當(dāng)前虛擬機(jī)的要求,不會(huì)危害虛擬機(jī)的安全,所以我們使用參數(shù)-Xverify:none 來禁用字節(jié)碼的驗(yàn)證過程

重啟IDEA

怎么在IntelliJ Idea中對(duì)JVM的性能進(jìn)行調(diào)試

耗時(shí)下降到了11s,效果還是比較明顯的

上述內(nèi)容就是怎么在IntelliJ Idea中對(duì)JVM的性能進(jìn)行調(diào)試,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)站欄目:怎么在IntelliJIdea中對(duì)JVM的性能進(jìn)行調(diào)試-創(chuàng)新互聯(lián)
標(biāo)題來源:http://vcdvsql.cn/article18/ddgpdp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司商城網(wǎng)站云服務(wù)器App設(shè)計(jì)靜態(tài)網(wǎng)站自適應(yīng)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名