• <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   管理


            久久av无码专区亚洲av桃花岛| 亚洲国产一成人久久精品| 国产一区二区三区久久精品| 久久r热这里有精品视频| 99久久精品免费看国产免费| 久久99精品久久久久久水蜜桃| 久久99精品久久久久久秒播| 久久精品亚洲AV久久久无码| 久久777国产线看观看精品| 久久久久国产视频电影| 东方aⅴ免费观看久久av| 国产精品一区二区久久| 伊人 久久 精品| 亚洲综合婷婷久久| 粉嫩小泬无遮挡久久久久久| 97精品伊人久久大香线蕉| 久久精品国产精品青草app| 久久久久亚洲AV无码观看| 爱做久久久久久| 久久精品a亚洲国产v高清不卡| 伊人久久一区二区三区无码| 国产女人aaa级久久久级| 亚洲国产精品无码久久| 色狠狠久久综合网| 国产高清美女一级a毛片久久w| 国产精品久久永久免费| 看久久久久久a级毛片| 一个色综合久久| 久久综合久久综合亚洲| 久久亚洲国产精品五月天婷| 久久综合九色综合97_久久久| 色88久久久久高潮综合影院| 久久国产AVJUST麻豆| 亚洲а∨天堂久久精品| 久久九九免费高清视频| 久久久久久极精品久久久| 国产精品伊人久久伊人电影| 久久天天躁狠狠躁夜夜av浪潮| 91精品日韩人妻无码久久不卡| 久久99精品国产99久久6男男| 久久99国产精品久久99|