1.內存設置(VM參數調優)
(1).
Windows環境下,是tomcat解壓版(執行startup.bat啓動tomcat) ,解決辦法:
修改「%TOMCAT_HOME%\bin\catalina.bat」文件,在文件開頭增長以下設置:
set JAVA_OPTS=-Xms512m -Xmx512m
-XX:PermSize=128M -XX:MaxNewSize=256m
-XX:MaxPermSize=512m
備註:必定加在catalina.bat最前面。
(2).
Windows環境下,是tomcat安裝版(利用windows的系統服務啓動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服務,設置生效。
(3). Linux環境下, ,解決辦法:
修改「%TOMCAT_HOME%\bin\catalina.sh」文件,在文件開頭增長以下設置:JAVA_OPTS=’-Xms256m
-Xmx512m’
各參數詳解:
-Xms:設置JVM初始內存大小(默認是物理內存的1/64)
-Xmx:設置JVM可使用的最大內存(默認是物理內存的1/4,建議:物理內存80%)
-Xmn:設置JVM最小內存(128-256m就夠了,通常不設置)
默認空餘堆內存小於
40%時,JVM就會增大堆直到-Xmx的最大限制;空餘堆內存大於70%時,JVM會減小堆直到-Xms的最小限制。所以服務器通常設置-Xms、
-Xmx相等以免在每次GC 後調整堆的大小。
在較大型的應用項目中,默認的內存是不夠的,有可能致使系統沒法運行。常見的問題是報Tomcat內存溢出錯誤「java.lang.OutOfMemoryError:
Java heap space」,從而致使客戶端顯示500錯誤。
-XX:PermSize :爲JVM啓動時Perm的內存大小
-XX:MaxPermSize :爲最大可佔用的Perm內存大小(默認爲32M)
-XX:MaxNewSize,默認爲16M
PermGen space的全稱是Permanent Generation
space,是指內存的永久保存區域,這塊內存主要是被JVM存放Class和Meta信息的,Class在被Loader時就會被放到PermGen
space中,它和存放類實例(Instance)的Heap區域不一樣,GC(Garbage
Collection)不會在主程序運行期對PermGen
space進行清理,因此若是你的應用中有很CLASS的話,就極可能出現「java.lang.OutOfMemoryError:
PermGen space」錯誤。
對於WEB項目,jvm加載類時,永久域中的對象急劇增長,從而使jvm不斷調整永久域大小,爲了不調整),你可使用更多的參數配置。若是你的WEB
APP下都用了大量的第三方jar, 其大小超過了jvm默認的大小,那麼就會產生此錯誤信息了。
其它參數:
-XX:NewSize :默認爲2M,此值設大可調大新對象區,減小Full
GC次數
-XX:NewRatio :改變新舊空間的比例,意思是新空間的尺寸是舊空間的1/8(默認爲8)
-XX:SurvivorRatio :改變Eden對象空間和殘存空間的尺寸比例,意思是Eden對象空
間的尺寸比殘存空間大survivorRatio+2倍(缺省值是10)
-XX:userParNewGC 可用來設置並行收集【多CPU】
-XX:ParallelGCThreads 可用來增長並行度【多CPU】
-XXUseParallelGC 設置後可使用並行清除收集器【多CPU】
2.修改tomcat讓其支持NIO
修改前:
protocol="HTTP/1.1"
connectionTimeout="20000" redirectPort="8443"/>
修改爲支持NIO的類型,配置以下 :
protocol="org.apache.coyote.http11.Http11NioProtocol
" connectionTimeout="20000" redirectPort="8443" />
3.併發數設置
默認的tomcat配置,併發測試時,可能30個USER上去就當機了。
添加
maxThreads="600" //最大線程數
minSpareThreads="100" //初始化時建立的線程數
maxSpareThreads="500" //一旦線程超過這個值,Tomcat會關閉不須要的socket線程
acceptCount="700"//指定當全部可使用的處理請求的線程數都被使用時,能夠放到
處理隊列中的請求數,超過這個數的請求將不予處理
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虛擬機調優
應該選擇SUN的JVM,在知足項目須要的前提下,儘可能選用版本較高的JVM,通常來講高版本產品在速度和效率上比低版本會有改進。
JDK1.4比JDK1.3性能提升了近10%-20%,JDK1.5比JDK1.4性能提升25%-75%。
5.禁用DNS查詢
設置enableLookups="false":
enableLookups="false"
redirectPort="8443" URIEncoding="UTF-8" acceptCount="1000"
/>
當web應用程序向要記錄客戶端的信息時,它也會記錄客戶端的IP地址或者經過域名服務器查找機器名轉換爲IP地址。DNS查詢須要佔用網絡,
而且包括可能從不少很遠的服務器或者不起做用的服務器上去獲取對應的IP的過程,這樣會消耗必定的時間。爲了消除DNS查詢對性能的影響咱們能夠關閉
DNS查詢,方式是修改server.xml文件中的enableLookups參數值爲false。
6.設置解決亂碼問題
URIEncoding="UTF-8"
acceptCount="1000" />java