java常用記憶體設定

來源:互聯網
上載者:User

標籤:

Java虛擬機器具有一個堆,是運行時的資料區域,所有類執行個體和數組記憶體均從此處分配。堆是在java虛擬機器啟動時建立的。

堆是留給開發人員用的記憶體地區。非堆就是JVM留給自己用的(方法區,JVM內部處理或最佳化所需的記憶體,運行時的常量池,欄位方法資料等)。


JVM初始分配的記憶體由-Xms指定,預設為實體記憶體的1/64;JVM最大分配的記憶體由-Xmx指定,預設是實體記憶體的1/4。

預設空餘堆記憶體小於40%時,JVM會增大到-Xmx的最大限制;空餘堆記憶體大於70%時,JVM會減少堆直到-Xms的最小限制。

因此伺服器一般設定-Xms,-Xmx相等以避免每次在GC後調整堆的大小。


JVM使用-XX:PermSize設定非堆區持久代(僅僅存在於HotSpot中的概念,最新的HotSpot中也進行
了移除)記憶體初始值,預設是實體記憶體的1/64;由XX:MaxPermSize設定最大的非堆記憶體的大小,預設是實體記憶體的1/4。

JVM記憶體限制(最大值)
32位的作業系統,處理器會控制記憶體空間有4G,64bit以上處理器就不會有限制

常用參數:
-Xmx Java Heap最大值,預設值為實體記憶體的1/4,最佳設值應該視實體記憶體大小及電腦內其他記憶體開銷而定;
-Xms   Java Heap初始值,Server端JVM最好將-Xms和-Xmx設定成相同值,開發測試機JVM可以保留預設值;
-Xmn   Java Heap Young區大小,增大年輕代後,將會減小年老代大小.此值對系統效能影響較大,Sun官方推薦配置為整個堆的3/8;
-Xss   每個線程的Stack大小,JDK5.0以後每個線程堆棧大小為1M,以前每個線程堆棧大小為256K;

java常用記憶體設定

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.