Tomcat的JVM和連接數設置

Windows環境下修改“%TOMCAT_HOME%\bin\catalina.bat”文件,在文件開頭增加如下設置:

set JAVA_OPTS=-Xms256m -Xmx512m

Linux環境下修改“%TOMCAT_HOME%\bin\catalina.sh”文件,在文件開頭增加如下設置:

JAVA_OPTS=’-Xms256m -Xmx512m’

其中,-Xms設置初始化內存大小,-Xmx設置可以使用的最大內存。

--------------------------------------

一、Tomcat的JVM提示內存溢出

查看%TOMCAT_HOME%\logs文件夾下,日誌文件是否有內存溢出錯誤

二、修改Tomcat的JVM

1、錯誤提示:java.lang.OutOfMemoryError: Java heap space

Tomcat默認可以使用的內存為128MB,在較大型的應用項目中,這點內存是不夠的,有可能導致系統無法運行。常見的問題是報Tomcat內存溢出錯誤,Out of Memory(系統內存不足)的異常,從而導致客戶端顯示500錯誤,一般調整Tomcat的使用內存即可解決此問題。

Windows環境下修改“%TOMCAT_HOME%\bin\catalina.bat”文件,在文件開頭增加如下設置:set JAVA_OPTS=-Xms256m -Xmx512m

Linux環境下修改“%TOMCAT_HOME%\bin\catalina.sh”文件,在文件開頭增加如下設置:JAVA_OPTS=’-Xms256m -Xmx512m’

其中,-Xms設置初始化內存大小,-Xmx設置可以使用的最大內存。

2、錯誤提示:java.lang.OutOfMemoryError: PermGen space

原因:

PermGen space的全稱是Permanent Generation space,是指內存的永久保存區域,這塊內存主要是被JVM存

放Class和Meta信息的,Class在被Loader時就會被放到PermGen space中,它和存放類實例(Instance)的

Heap區域不同,GC(Garbage Collection)不會在主程序運行期對PermGen space進行清理,所以如果你的應用

中有很CLASS的話,就很可能出現PermGen space錯誤,這種錯誤常見在web服務器對JSP進行pre compile的

時候。如果你的WEB APP下都用了大量的第三方jar, 其大小超過了jvm默認的大小(4M)那麼就會產生此錯誤信

息了。

解決方法:

在catalina.bat的第一行增加:

set JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128M -XX:MaxNewSize=256m -

XX:MaxPermSize=256m

在catalina.sh的第一行增加:

JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128M -XX:MaxNewSize=256m -

XX:MaxPermSize=256m

最終解決方案:(直接編輯所用的JVM)

在Run/Debug editconfiguration 的你要運行的tomcat裡面的

vm options裡面輸入:

-server -XX:PermSize=256M -XX:MaxPermSize=512m
Tomcat的JVM和連接數設置

3、JVM設置

堆的尺寸

-Xmssize in bytes

設定Java堆的初始尺寸,缺省尺寸是2097152 (2MB)。這個值必須是1024個字節(1KB)的倍數,且比它大。(-server選項把缺省尺寸增加到32M。)

-Xmnsize in bytes

為Eden對象設定初始Java堆的大小,缺省值為640K。(-server選項把缺省尺寸增加到2M。)

-Xmxsize in bytes

設定Java堆的最大尺寸,缺省值為64M,(-server選項把缺省尺寸增加到128M。) 最大的堆尺寸達到將近2GB(2048MB)。

請注意:很多垃圾收集器的選項依賴於堆大小的設定。請在微調垃圾收集器使用內存空間的方式之前,確認是否已經正確設定了堆的尺寸。

垃圾收集:內存的使用

-XX:MinHeapFreeRatio=percentage as a whole number

修改垃圾回收之後堆中可用內存的最小百分比,缺省值是40。如果垃圾回收後至少還有40%的堆內存沒有被釋放,則系統將增加堆的尺寸。

-XX:MaxHeapFreeRatio=percentage as a whole number

改變垃圾回收之後和堆內存縮小之前可用堆內存的最大百分比,缺省值為70。這意味著如果在垃圾回收之後還有大於70%的堆內存,則系統就會減少堆的尺寸。

-XX:NewSize=size in bytes

為已分配內存的對象中的Eden代設置缺省的內存尺寸。它的缺省值是640K。(-server選項把缺省尺寸增加到2M。)

-XX:MaxNewSize=size in bytes

允許您改變初期對象空間的上限,新建對象所需的內存就是從這個空間中分配來的,這個選項的缺省值是640K。(-server選項把缺省尺寸增加到2M。)

-XX:NewRatio=value

改變新舊空間的尺寸比例,這個比例的缺省值是8,意思是新空間的尺寸是舊空間的1/8。

-XX:SurvivorRatio=number

改變Eden對象空間和殘存空間的尺寸比例,這個比例的缺省值是10,意思是Eden對象空間的尺寸比殘存空間大survivorRatio+2倍。

-XX:TargetSurvivorRatio=percentage

設定您所期望的空間提取後被使用的殘存空間的百分比,缺省值是50。

-XX:MaxPermSize=size in MB

長久代(permanent generation)的尺寸,缺省值為32(32MB)。

三、查看Tomcat的JVM內存

1. Tomcat6中沒有設置任何默認用戶,因而需要手動往Tomcat6的conf文件夾下的tomcat-users.xml文件中添加用戶。

如:<role>

<user>

注:添加完需要重啟Tomcat6。

2. 訪問http://localhost:8080/manager/status,輸入上面添加的用戶名和密碼。

3. 然後在如下面的JVM下可以看到內存的使用情況。

JVM

Free memory: 2.50 MB Total memory: 15.53 MB Max memory: 63.56 MB

四、Tomcat連接數設置

在tomcat配置文件server.xml中的<connector>配置中,和連接數相關的參數有:

minProcessors:最小空閒連接線程數,用於提高系統處理性能,默認值為10

maxProcessors:最大連接線程數,即:併發處理的最大請求數,默認值為75

acceptCount:允許的最大連接數,應大於等於maxProcessors,默認值為100

enableLookups:是否反查域名,取值為:true或false。為了提高處理能力,應設置為false

connectionTimeout:網絡連接超時,單位:毫秒。設置為0表示永不超時,這樣設置有隱患的。通常可設置為30000毫秒。

其中和最大連接數相關的參數為maxProcessors和acceptCount。如果要加大併發連接數,應同時加大這兩個參數。

web server允許的最大連接數還受制於操作系統的內核參數設置,通常Windows是2000個左右,Linux是1000個左右。Unix中如何設置這些參數,請參閱Unix常用監控和管理命令


分享到:


相關文章: