• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            大龍的博客

            常用鏈接

            統(tǒng)計(jì)

            最新評論

            解決JVM最大內(nèi)存設(shè)置問題

            你知道JVM內(nèi)存最大能調(diào)多大嗎,這里和大家分享一下JVM最大內(nèi)存方面的內(nèi)容,Java虛擬機(jī)具有一個(gè)堆,堆是運(yùn)行時(shí)數(shù)據(jù)區(qū)域,所有類實(shí)例和數(shù)組的內(nèi)存均從此處分配。堆是在Java虛擬機(jī)啟動(dòng)時(shí)創(chuàng)建的。

            JVM內(nèi)存最大能調(diào)多大

            今天分析了當(dāng)前比較流行的幾個(gè)不同公司不同版本JVM最大內(nèi)存,得出來的結(jié)果如下:

            公司JVM版本最大內(nèi)存(兆)client最大內(nèi)存(兆)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版本都運(yùn)行在Windows操作系統(tǒng)下

            如何獲得JVM最大內(nèi)存

            在命令行下用java-XmxXXXXM-version命令來進(jìn)行測試,然后逐漸的增大XXXX的值,如果執(zhí)行正常就表示指定的內(nèi)存大小可用,否則會(huì)打印錯(cuò)誤信息。

            實(shí)際發(fā)現(xiàn)版本上有細(xì)微差別的JDK最大容許內(nèi)存值都不盡相同,因此在實(shí)際的應(yīng)用中還是要自己試驗(yàn)一下看到底內(nèi)存能達(dá)到什么樣的值。

            通過這個(gè)表想說明的是,如果你的機(jī)器的內(nèi)存太多的話,只能通過多運(yùn)行幾個(gè)實(shí)例來提供機(jī)器的利用率了,例如跑Tomcat,你可以多裝幾個(gè)Tomcat并做集群,依此類推。

            ◆堆(Heap)和非堆(Non-heap)內(nèi)存

            按照官方的說法:"Java虛擬機(jī)具有一個(gè)堆,堆是運(yùn)行時(shí)數(shù)據(jù)區(qū)域,所有類實(shí)例和數(shù)組的內(nèi)存均從此處分配。堆是在Java虛擬機(jī)啟動(dòng)時(shí)創(chuàng)建的。""在JVM中堆之外的內(nèi)存稱為非堆內(nèi)存(Non-heapmemory)"。可以看出JVM主要管理兩種類型的內(nèi)存:堆和非堆。簡單來說堆就是Java代碼可及的內(nèi)存,是留給開發(fā)人員使用的;非堆就是JVM留給自己用的,所以方法區(qū)、JVM內(nèi)部處理或優(yōu)化所需的內(nèi)存(如JIT編譯后的代碼緩存)、每個(gè)類結(jié)構(gòu)(如運(yùn)行時(shí)常數(shù)池、字段和方法數(shù)據(jù))以及方法和構(gòu)造方法的代碼都在非堆內(nèi)存中。

            ◆堆內(nèi)存分配

            JVM初始分配的內(nèi)存由-Xms指定,默認(rèn)是物理內(nèi)存的1/64;JVM最大分配的內(nèi)存由-Xmx指定,默認(rèn)是物理內(nèi)存的1/4。默認(rèn)空余堆內(nèi)存小于40%時(shí),JVM就會(huì)增大堆直到-Xmx的最大限制;空余堆內(nèi)存大于70%時(shí),JVM會(huì)減少堆直到-Xms的最小限制。因此服務(wù)器一般設(shè)置-Xms、-Xmx相等以避免在每次GC后調(diào)整堆的大小。

            ◆非堆內(nèi)存分配

            JVM使用-XX:PermSize設(shè)置非堆內(nèi)存初始值,默認(rèn)是物理內(nèi)存的1/64;由XX:MaxPermSize設(shè)置最大非堆內(nèi)存的大小,默認(rèn)是物理內(nèi)存的1/4。

            ◆JVM最大內(nèi)存

            首先JVM內(nèi)存限制于實(shí)際的最大物理內(nèi)存(廢話!呵呵),假設(shè)物理內(nèi)存無限大的話,JVM內(nèi)存的最大值跟操作系統(tǒng)有很大的關(guān)系。簡單的說就32位處理器雖然可控內(nèi)存空間有4GB,但是具體的操作系統(tǒng)會(huì)給一個(gè)限制,這個(gè)限制一般是2GB-3GB(一般來說Windows系統(tǒng)下為1.5G-2G,Linux系統(tǒng)下為2G-3G),而64bit以上的處理器就不會(huì)有限制了。


            本文地址,轉(zhuǎn)載請注明出處:http://www.aijiw.com/art/20110808/09284120.htm 

            posted on 2011-10-09 23:55 大龍 閱讀(349) 評論(0)  編輯 收藏 引用


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            欧美丰满熟妇BBB久久久| 国产L精品国产亚洲区久久| 亚洲人成网亚洲欧洲无码久久| 综合人妻久久一区二区精品| 精品久久久久久中文字幕| 午夜精品久久久久成人| 国产精品久久成人影院| 色老头网站久久网| 亚洲国产精品久久66| 久久久噜噜噜久久熟女AA片| 久久夜色精品国产亚洲av| 久久精品视频网| 久久久精品国产sm调教网站| 亚洲国产精品嫩草影院久久 | 久久久精品一区二区三区| 伊人久久大香线蕉成人| 伊人久久免费视频| 九九久久99综合一区二区| 久久久亚洲欧洲日产国码二区| 四虎国产精品成人免费久久| 精品久久久久一区二区三区| 久久综合久久久| 青青国产成人久久91网| 久久久久成人精品无码中文字幕 | 国产精品免费看久久久| 亚洲国产小视频精品久久久三级 | 久久se精品一区二区| 国内精品久久久久久99蜜桃| 久久久久亚洲av成人网人人软件 | 亚洲精品白浆高清久久久久久| 久久中文字幕无码专区| 国产99久久九九精品无码| 久久99国产精品成人欧美| 国产免费久久久久久无码| 伊人色综合久久天天| 久久精品亚洲欧美日韩久久| 久久乐国产精品亚洲综合| 午夜精品久久久久久影视riav| 中文成人无码精品久久久不卡| 三级三级久久三级久久| 亚洲AV无码久久|