1.內(nèi)存設(shè)置(VM參數(shù)調(diào)優(yōu))
(1). Windows環(huán)境下,是tomcat解壓版(執(zhí)行startup.bat啟動tomcat) ,解決辦法:
修改“%TOMCAT_HOME%\bin\catalina.bat”文件,在文件開頭增加如下設(shè)置:
set JAVA_OPTS=-Xms512m -Xmx512m -XX:PermSize=128M -XX:MaxNewSize=256m -XX:MaxPermSize=512m
備注:一定加在catalina.bat最前面。
(2). Windows環(huán)境下,是tomcat安裝版(利用windows的系統(tǒng)服務(wù)啟動tomcat),解決辦法:
修改注冊表HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Procrun 2.0\Tomcat6\Parameters\JavaOptions
原值為:
-Dcatalina.home=E:\Tomcat 6.0
-Dcatalina.base=E:\Tomcat 6.0
-Djava.endorsed.dirs=E:\Tomcat 6.0\common\endorsed
-Djava.io.tmpdir=E:\Tomcat 6.0\temp
-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
-Djava.util.logging.config.file=E:\Tomcat 6.0\conf\logging.properties
加入:
Xms512m -Xmx512m -XX:PermSize=128M -XX:MaxNewSize=256m -XX:MaxPermSize=512m
重起tomcat服務(wù),設(shè)置生效。
(3). Linux環(huán)境下, ,解決辦法:
修改“%TOMCAT_HOME%\bin\catalina.sh”文件,在文件開頭增加如下設(shè)置:JAVA_OPTS=’-Xms256m -Xmx512m’
各參數(shù)詳解:
-Xms:設(shè)置JVM初始內(nèi)存大小(默認是物理內(nèi)存的1/64)
-Xmx:設(shè)置JVM可以使用的最大內(nèi)存(默認是物理內(nèi)存的1/4,建議:物理內(nèi)存80%)
-Xmn:設(shè)置JVM最小內(nèi)存(128-256m就夠了,一般不設(shè)置)
默認空余堆內(nèi)存小于 40%時,JVM就會增大堆直到-Xmx的最大限制;空余堆內(nèi)存大于70%時,JVM會減少堆直到-Xms的最小限制。因此服務(wù)器一般設(shè)置-Xms、 -Xmx相等以避免在每次GC 后調(diào)整堆的大小。
在較大型的應(yīng)用項目中,默認的內(nèi)存是不夠的,有可能導(dǎo)致系統(tǒng)無法運行。常見的問題是報Tomcat內(nèi)存溢出錯誤“java.lang.OutOfMemoryError: Java heap space”,從而導(dǎo)致客戶端顯示500錯誤。
-XX:PermSize :為JVM啟動時Perm的內(nèi)存大小
-XX:MaxPermSize :為最大可占用的Perm內(nèi)存大小(默認為32M)
-XX:MaxNewSize,默認為16M
PermGen space的全稱是Permanent Generation space,是指內(nèi)存的永久保存區(qū)域,這塊內(nèi)存主要是被JVM存放Class和Meta信息的,Class在被Loader時就會被放到PermGen space中,它和存放類實例(Instance)的Heap區(qū)域不同,GC(Garbage Collection)不會在主程序運行期對PermGen space進行清理,所以如果你的應(yīng)用中有很CLASS的話,就很可能出現(xiàn)“java.lang.OutOfMemoryError: PermGen space”錯誤。
對于WEB項目,jvm加載類時,永久域中的對象急劇增加,從而使jvm不斷調(diào)整永久域大小,為了避免調(diào)整),你可以使用更多的參數(shù)配置。如果你的WEB APP下都用了大量的第三方j(luò)ar, 其大小超過了jvm默認的大小,那么就會產(chǎn)生此錯誤信息了。
其它參數(shù):
-XX:NewSize :默認為2M,此值設(shè)大可調(diào)大新對象區(qū),減少Full GC次數(shù)
-XX:NewRatio :改變新舊空間的比例,意思是新空間的尺寸是舊空間的1/8(默認為8)
-XX:SurvivorRatio :改變Eden對象空間和殘存空間的尺寸比例,意思是Eden對象空
間的尺寸比殘存空間大survivorRatio+2倍(缺省值是10)
-XX:userParNewGC 可用來設(shè)置并行收集【多CPU】
-XX:ParallelGCThreads 可用來增加并行度【多CPU】
-XXUseParallelGC 設(shè)置后可以使用并行清除收集器【多CPU】
2.修改tomcat讓其支持NIO
修改前:
protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443"/>
修改成支持NIO的類型,配置如下 :
protocol="org.apache.coyote.http11.Http11NioProtocol " connectionTimeout="20000" redirectPort="8443" />
3.并發(fā)數(shù)設(shè)置
默認的tomcat配置,并發(fā)測試時,可能30個USER上去就當機了。
添加
maxThreads="600" //最大線程數(shù)
minSpareThreads="100" //初始化時創(chuàng)建的線程數(shù)
maxSpareThreads="500" //一旦線程超過這個值,Tomcat會關(guān)閉不需要的socket線程
acceptCount="700"http://指定當所有可以使用的處理請求的線程數(shù)都被使用時,可以放到
處理隊列中的請求數(shù),超過這個數(shù)的請求將不予處理
connectionTimeout="20000"
redirectPort="8443" />
或者
name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="400" />
executor="tomcatThreadPool" port="80" protocol="HTTP/1.1" connectionTimeout="20000" enableLookups="false"
redirectPort="8443" URIEncoding="UTF-8" acceptCount="1000" />
4.Java虛擬機調(diào)優(yōu)
應(yīng)該選擇SUN的JVM,在滿足項目需要的前提下,盡量選用版本較高的JVM,一般來說高版本產(chǎn)品在速度和效率上比低版本會有改進。 JDK1.4比JDK1.3性能提高了近10%-20%,JDK1.5比JDK1.4性能提高25%-75%。
5.禁用DNS查詢
設(shè)置enableLookups="false":
enableLookups="false" redirectPort="8443" URIEncoding="UTF-8" acceptCount="1000" />
當web應(yīng)用程序向要記錄客戶端的信息時,它也會記錄客戶端的IP地址或者通過域名服務(wù)器查找機器名轉(zhuǎn)換為IP地址。DNS查詢需要占用網(wǎng)絡(luò),并且包括可能從很多很遠的服務(wù)器或者不起作用的服務(wù)器上去獲取對應(yīng)的IP的過程,這樣會消耗一定的時間。為了消除DNS查詢對性能的影響我們可以關(guān)閉 DNS查詢,方式是修改server.xml文件中的enableLookups參數(shù)值為false。
6.設(shè)置解決亂碼問題
URIEncoding="UTF-8" acceptCount="1000" />
二、TOMCAT內(nèi)存監(jiān)控
1.設(shè)置tomcat的perm size:
2.開啟監(jiān)控
在命令行輸入jconsole,在彈出窗口中建立本地端口監(jiān)控,如下圖:
使用安裝版Tomcat 6.0 ,打開tomcat界面選擇java這一項,在java options:
加入
- -Djava.rmi.server.hostname=127.0.0.1
- -Dcom.sun.management.jmxremote.port=8088
- -Dcom.sun.management.jmxremote.ssl=false
- -Dcom.sun.management.jmxremote.authenticate=false
- -Djava.rmi.server.hostname=127.0.0.1
- -Dcom.sun.management.jmxremote.port=8088
- -Dcom.sun.management.jmxremote.ssl=false
- -Dcom.sun.management.jmxremote.authenticate=false
使用jconsole 127.0.0.1:8088可以連接成功,也能看到j(luò)vm運行情況,
但此時訪問已經(jīng)部署的應(yīng)用,卻提示“無法顯示網(wǎng)頁”
今天又研究了一會,猜想了一下是不是這個端口獨占的,不能和應(yīng)用沖突,把Dcom.sun.management.jmxremote.port=8088 改為80, 重啟tomcat 果然,應(yīng)用可以訪問。之后去網(wǎng)上看來些相關(guān)信息,確實為兩個端口,不能占用。