1. 程式人生 > >JVM系列:解決JVM最大記憶體設定問題

JVM系列:解決JVM最大記憶體設定問題

你知道JVM記憶體最大能調多大嗎,這裡和大家分享一下JVM最大記憶體方面的內容,Java虛擬機器具有一個堆,堆是執行時資料區域,所有類例項和陣列的記憶體均從此處分配。堆是在Java虛擬機器啟動時建立的。

JVM記憶體最大能調多大

今天分析了當前比較流行的幾個不同公司不同版本JVM最大記憶體,得出來的結果如下:

公司JVM版本最大記憶體(兆)client最大記憶體(兆)server
SUN1.5.x14921520
SUN1.5.5(Linux)26342660
SUN1.4.215641564
SUN1.4.2(Linux)19001260
IBM1.4.2(Linux)2047N/A
BEAJRockit1.5(U3)19091902

除非特別說明,否則JVM版本都執行在Windows作業系統下

如何獲得JVM最大記憶體

在命令列下用java-XmxXXXXM-version命令來進行測試,然後逐漸的增大XXXX的值,如果執行正常就表示指定的記憶體大小可用,否則會列印錯誤資訊。

實際發現版本上有細微差別的JDK最大容許記憶體值都不盡相同,因此在實際的應用中還是要自己試驗一下看到底記憶體能達到什麼樣的值。

通過這個表想說明的是,如果你的機器的記憶體太多的話,只能通過多執行幾個例項來提供機器的利用率了,例如跑Tomcat,你可以多裝幾個Tomcat並做叢集,依此類推。

◆堆(Heap)和非堆(Non-heap)記憶體

按照官方的說法:“Java虛擬機器具有一個堆,堆是執行時資料區域,所有類例項和陣列的記憶體均從此處分配。堆是在Java虛擬機器啟動時建立的。”“在JVM中堆之外的記憶體稱為非堆記憶體(Non-heapmemory)”。可以看出JVM主要管理兩種型別的記憶體:堆和非堆。簡單來說堆就是Java程式碼可及的記憶體,是留給開發人員使用的;非堆就是JVM留給自己用的,所以方法區、JVM內部處理或優化所需的記憶體(如JIT編譯後的程式碼快取)、每個類結構(如執行時常數池、欄位和方法資料)以及方法和構造方法的程式碼都在非堆記憶體中。

◆堆記憶體分配

JVM初始分配的記憶體由-Xms指定,預設是實體記憶體的1/64;JVM最大分配的記憶體由-Xmx指定,預設是實體記憶體的1/4。預設空餘堆記憶體小於40%時,JVM就會增大堆直到-Xmx的最大限制;空餘堆記憶體大於70%時,JVM會減少堆直到-Xms的最小限制。因此伺服器一般設定-Xms、-Xmx相等以避免在每次GC後調整堆的大小。

◆非堆記憶體分配

JVM使用-XX:PermSize設定非堆記憶體初始值,預設是實體記憶體的1/64;由XX:MaxPermSize設定最大非堆記憶體的大小,預設是實體記憶體的1/4。

◆JVM最大記憶體

首先JVM記憶體限制於實際的最大實體記憶體(廢話!呵呵),假設實體記憶體無限大的話,JVM記憶體的最大值跟作業系統有很大的關係。簡單的說就32位處理器雖然可控記憶體空間有4GB,但是具體的作業系統會給一個限制,這個限制一般是2GB-3GB(一般來說Windows系統下為1.5G-2G,Linux系統下為2G-3G),而64bit以上的處理器就不會有限制了。