国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > 如何進(jìn)行JVM性能調(diào)優(yōu)?

如何進(jìn)行JVM性能調(diào)優(yōu)?

來(lái)源:千鋒教育
發(fā)布人:qyf
時(shí)間: 2022-09-21 16:16:51 1663748211

如何進(jìn)行JVM性能調(diào)優(yōu)

  1. 監(jiān)控GC的狀態(tài)

  使用各種JVM工具,查看當(dāng)前日志,分析當(dāng)前JVM參數(shù)設(shè)置,并且分析當(dāng)前堆內(nèi)存快照和gc日志,根據(jù)實(shí)際的各區(qū)域內(nèi)存劃分和GC執(zhí)行時(shí)間,覺得是否進(jìn)行優(yōu)化。

  2. 系統(tǒng)崩潰前的一些現(xiàn)象:

  每次垃圾回收的時(shí)間越來(lái)越長(zhǎng),由之前的10ms延長(zhǎng)到50ms左右,F(xiàn)ullGC的時(shí)間也有之前的0.5s延長(zhǎng)到4、5s

  FullGC的次數(shù)越來(lái)越多,最頻繁時(shí)隔不到1分鐘就進(jìn)行一次FullGC

  年老代的內(nèi)存越來(lái)越大并且每次FullGC后年老代沒有內(nèi)存被釋放

  之后系統(tǒng)會(huì)無(wú)法響應(yīng)新的請(qǐng)求,逐漸到達(dá)OutOfMemoryError的臨界值,這個(gè)時(shí)候就需要分析JVM內(nèi)存快照dump。

  3. 生成堆的dump文件

  通過JMX的MBean生成當(dāng)前的Heap信息,大小為一個(gè)3G(整個(gè)堆的大小)的hprof文件,如果沒有啟動(dòng)JMX可以通過Java的jmap命令來(lái)生成該文件。

  4. 分析dump文件

  打開這個(gè)3G的堆信息文件,顯然一般的Window系統(tǒng)沒有這么大的內(nèi)存,必須借助高配置的Linux,幾種工具打開該文件:

  Visual VM

  IBM HeapAnalyzer

  JDK 自帶的Hprof工具

  Mat(Eclipse專門的靜態(tài)內(nèi)存分析工具)推薦使用

  備注:文件太大,建議使用Eclipse專門的靜態(tài)內(nèi)存分析工具M(jìn)at打開分析。

  5. 分析結(jié)果,判斷是否需要優(yōu)化

  如果各項(xiàng)參數(shù)設(shè)置合理,系統(tǒng)沒有超時(shí)日志出現(xiàn),GC頻率不高,GC耗時(shí)不高,那么沒有必要進(jìn)行GC優(yōu)化,如果GC時(shí)間超過1-3秒,或者頻繁GC,則必須優(yōu)化。

  注:如果滿足下面的指標(biāo),則一般不需要進(jìn)行GC:

  Minor GC執(zhí)行時(shí)間不到50ms;

  Minor GC執(zhí)行不頻繁,約10秒一次;

  Full GC執(zhí)行時(shí)間不到1s;

  Full GC執(zhí)行頻率不算頻繁,不低于10分鐘1次;

  6.調(diào)整GC類型和內(nèi)存分配

  如果內(nèi)存分配過大或過小,或者采用的GC收集器比較慢,則應(yīng)該優(yōu)先調(diào)整這些參數(shù),并且先找1臺(tái)或幾臺(tái)機(jī)器進(jìn)行beta,然后比較優(yōu)化過的機(jī)器和沒有優(yōu)化的機(jī)器的性能對(duì)比,并有針對(duì)性的做出最后選擇。

  7. 不斷的分析和調(diào)整

  通過不斷的試驗(yàn)和試錯(cuò),分析并找到最合適的參數(shù),如果找到了最合適的參數(shù),則將這些參數(shù)應(yīng)用到所有服務(wù)器。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
什么是域控制器?

一、域控制器的定義域控制器是指在Windows Server操作系統(tǒng)中部署Active Directory服務(wù)的服務(wù)器。Active Directory是微軟公司開發(fā)的目錄服務(wù),用...詳情>>

2023-10-15 00:10:28
深度學(xué)習(xí)模型權(quán)重h5、weights、ckpt、pth有什么區(qū)別?

1.來(lái)源框架不同h5格式通常用于Keras和TensorFlow框架,weights用于Darknet框架,ckpt是TensorFlow框架的一種格式,而pth則主要用于PyTorch框架...詳情>>

2023-10-15 00:05:17
大數(shù)據(jù)測(cè)試工程師需要具備哪些技能?

一、理解大數(shù)據(jù)概念大數(shù)據(jù)測(cè)試工程師需要理解大數(shù)據(jù)的基本概念和原理,如分布式存儲(chǔ)、MapReduce、實(shí)時(shí)計(jì)算等。他們還需要了解如何處理大規(guī)模的...詳情>>

2023-10-14 23:43:03
為什么SpringBoot的 jar 可以直接運(yùn)行?

一、JAR文件的結(jié)構(gòu)與執(zhí)行方式Spring Boot的JAR包是Java Archive的縮寫,它是一種壓縮文件格式,可以將Java項(xiàng)目的類文件、資源文件以及依賴庫(kù)等...詳情>>

2023-10-14 23:01:49
站群服務(wù)器是什么?

站群服務(wù)器的含義與用途站群服務(wù)器主要用于支持站群,即由一組相互鏈接的網(wǎng)站組成的群體。這些網(wǎng)站通常由同一組織或個(gè)人擁有,并且經(jīng)常會(huì)互相鏈...詳情>>

2023-10-14 22:46:12
快速通道