資源描述:
《jvm 內(nèi)存管理機(jī)制分析與oom問(wèn)題淺析》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在教育資源-天天文庫(kù)。
1、JVM內(nèi)存管理機(jī)制分析與OOM問(wèn)題淺析主講內(nèi)容如下了解Java基本內(nèi)存管理基本概念了解Jvm參數(shù)的參數(shù)配置及其作用了解發(fā)生內(nèi)存不足/內(nèi)存泄露錯(cuò)誤的主要原因如何診斷內(nèi)存不足/內(nèi)存泄露使用分析工具分析內(nèi)存不足和內(nèi)存泄露OOM錯(cuò)誤實(shí)例了解Java基本內(nèi)存管理基本概念Java內(nèi)存包括哪幾部分?Java堆內(nèi)存(Heap)Permanent區(qū)(Sun/HpJDK)本地內(nèi)存(NativeMemory)Java堆內(nèi)存(Heap):是JVM用于分配Java對(duì)象的內(nèi)存,包含活動(dòng)對(duì)象和freed對(duì)象堆大小使用java命令中的–Xms(最小)–Xm
2、x(最大)標(biāo)志來(lái)定義。Permanent區(qū):是SunJDK和HPJDK用來(lái)加載類(lèi)(class)的專(zhuān)門(mén)的內(nèi)存區(qū)這個(gè)區(qū)域不歸屬Java堆內(nèi)存(Heap)范圍如果Java應(yīng)用很大,例如類(lèi)(class)很多,那么建議增大這個(gè)區(qū)域的大小來(lái)滿足加載這些類(lèi)的內(nèi)存需求通過(guò)–XX:PermSize=***M–XX:MaxPermSize=***M調(diào)整了解Java基本內(nèi)存管理基本概念本地內(nèi)存(NativeMemory)是JVM用于其內(nèi)部操作的本地內(nèi)存(非Java內(nèi)存)JNI代碼和第三方本地模塊(例如,本地JDBC驅(qū)動(dòng)程序)也使用本地內(nèi)存最大本
3、地內(nèi)存大小取決于以下因素:操作系統(tǒng)進(jìn)程內(nèi)存大小限制已經(jīng)指定用于Java堆的內(nèi)存進(jìn)程的內(nèi)存大小等于什么?32位操作系統(tǒng),理論最大值2的32次方=4G64位操作系統(tǒng),理論最大值是一個(gè)很大的數(shù)字進(jìn)程內(nèi)存=Java(Heap)+本地內(nèi)存+加載的可執(zhí)行文件和庫(kù)+操作系統(tǒng)保留內(nèi)存了解Java基本內(nèi)存管理基本概念Java堆內(nèi)存大小的決定因素:進(jìn)程大小限制,例如:<=4G“加載的可執(zhí)行文件和庫(kù)+系統(tǒng)保留內(nèi)存”不同操作系統(tǒng)和應(yīng)用不一樣,通常在百M(fèi)到1G間JVM的本地內(nèi)存在不同的JDK之間也不一樣。JRockit相對(duì)SunJDK,做了非常好的J
4、IT優(yōu)化,但是本地內(nèi)存要求更多的空間通常Java堆內(nèi)存大小推薦不大于2G大部分操作系統(tǒng)默認(rèn)也上不到2G,需要做內(nèi)核調(diào)整--大內(nèi)存模式Java堆內(nèi)存的大內(nèi)存模式:PlatformDefaultMaximumHeapSizeWindowsona64bitplatform75%oftotalphysicalmemoryupto3GBLinuxorSolarisona64bitplatform75%ofphysicalmemoryupto3GBWindowsona32bitplatform75%oftotalphysicalmemo
5、ryupto1GBLinuxorSolarisona32bitplatform75%ofphysicalmemoryupto1GB了解Java基本內(nèi)存管理基本概念垃圾回收(GarbageCollection,GC)的作用:JVM自動(dòng)檢測(cè)和釋放不再使用的內(nèi)存。Java運(yùn)行時(shí)JVM會(huì)執(zhí)行GC,這樣程序員不再需要顯式釋放對(duì)象。通常在空閑內(nèi)存降低到某一水平或內(nèi)存分配達(dá)到某一數(shù)量后自動(dòng)觸發(fā)。各種JDK的垃圾回收都有多種算法和策略(預(yù)了解詳情請(qǐng)參考附件)以下OutOfMemory簡(jiǎn)稱(chēng)OOM以下MemoryLeak簡(jiǎn)稱(chēng)MLJava內(nèi)存
6、的兩種表現(xiàn)形式Java內(nèi)存問(wèn)題的兩種表現(xiàn)形式:內(nèi)存溢出錯(cuò)誤(OOM)內(nèi)存泄露錯(cuò)誤(ML)現(xiàn)在先不管這兩種內(nèi)存問(wèn)題是什么愿意導(dǎo)致的,但是最終它們都會(huì)拋出同樣的內(nèi)容:java.lang.OutOfMemoryError共同點(diǎn)是什么呢?沒(méi)有空閑內(nèi)存可供JVM或本地代碼用于分配新對(duì)象或內(nèi)存塊通常最終的狀態(tài)就會(huì)導(dǎo)致OOM錯(cuò)誤在Java堆或本地內(nèi)存中都可能發(fā)生不同點(diǎn)是什么呢?ML是已經(jīng)分配好的內(nèi)存或?qū)ο?,?dāng)不再需要,沒(méi)有得到釋放而OOM則是沒(méi)有足夠的空間來(lái)供jvm分配新的內(nèi)存塊ML的內(nèi)存曲線總體上是一條斜向上的曲線而OOM不是那樣子的J
7、ava內(nèi)存問(wèn)題的兩個(gè)主要發(fā)生區(qū)段Java內(nèi)存問(wèn)題的兩個(gè)主要發(fā)生區(qū)段:Java內(nèi)存--包括heap堆內(nèi)存和permanent區(qū)本地內(nèi)存--包括JVM進(jìn)程內(nèi)存和java使用的第三方本地代碼Java內(nèi)存不足Java堆內(nèi)存heap不足,無(wú)法再分配新對(duì)象或內(nèi)存塊permanent區(qū)內(nèi)存不足,無(wú)法再加載類(lèi)到內(nèi)存中(Sun&HpJDK)本地內(nèi)存不足物理內(nèi)存不夠,無(wú)法再得到內(nèi)存第三方本地代碼有內(nèi)存泄漏的BugJVM的JIT或者JVM本身的Bug(很古老的技術(shù)啦)物理內(nèi)存和虛擬內(nèi)存計(jì)算機(jī)的可尋址空間=RAM+交換空間進(jìn)程A的虛擬內(nèi)存進(jìn)程D的虛
8、擬內(nèi)存進(jìn)程B的虛擬內(nèi)存進(jìn)程C的虛擬內(nèi)存RAM交換空間進(jìn)程的虛擬內(nèi)存由OS映射到物理內(nèi)存本地內(nèi)存可執(zhí)行文件/庫(kù)Os使用本地內(nèi)存Os使用本地內(nèi)存Os使用本地內(nèi)存Os使用JavaheapJavaheapJavaheapJavaheap可執(zhí)行文件/庫(kù)可執(zhí)行文件/庫(kù)可執(zhí)行文件/庫(kù)當(dāng)然了,進(jìn)程大小受到