tomcat及jvm優化

1.conf/server.xml

將<Connector port="8080" protocol="HTTP/1.1"修改爲<Connectorport="8080"protocol="org.apache.coyote.http11.Http11NioProtocol"

前一個不能支持太高併發

設置tomcat最大併發數,方法:修改conf/server.xml,在Connector下增加以下代碼:maxThreads="1000" minSpareThreads="100" maxSpareThreads="300"  acceptCount="100"

maxThreads:最大線程數
minSpareThreads:初始化時創建的線程數
maxSpareThreads:一旦創建的線程超過這個值,Tomcat就會關閉不再需要的socket線程。
acceptCount:指定當所有可以使用的處理請求的線程數都被使用時,可以放到處理隊列中的請求數,超過這個數的請求將不予處理


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

web server允許的最大連接數還受制於操作系統的內核參數設置,通常Windows是2000個左右,Linux是1000個左右。

2.修改META-INF下的context.xml文件,在Context中增加一行:<Resources cachingAllowed="false"></Resources>

    避免高併發訪問圖片不停地寫warn日誌

3.設置tomcat的jvm較大內存,編輯bin/catalina.sh,找到以下代碼段:rem Guess CATALINA_HOME if not defined,在其上面增加代碼:


     JAVA_OPTS=-Xms512m -Xmx4096m -XX:PermSize=128M -XX:MaxPermSize=256m

-xms 最小堆大小

-xmx最大堆大小

-Xms和-Xmx設置相同時可避免Java堆自動擴展,過小或報java.lang.OutOfMemory:Java heap space


PermSize和MaxPermSize: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)那麼就會產生此錯誤信
息了。

過小會報:java.lang.OutOfMemoryError: PermGen


4.使用nginx或者apache做靜態代理,tomcat集羣


5.tomcat做apr配置

Linux下,Tomcat啓用APR需要三個組件:
apr
apr-util
tomcat-native.tar.gz(Tomcat自帶,在bin目錄下)


1、查看是否已經安裝了apr和apr-util
# rpm -qa apr
apr-1.4.8-3.el7.x86_64
 
# rpm -qa apr-util
apr-util-1.5.2-6.el7.x86_64


2、查看是否有最新版的apr和apr-util

3、如果還沒安裝,用yum安裝:
# yum install apr-devel apr apr-util


4、安裝tomcat-native:
搜索tomcat-native安裝包:
# yum list | grep tomcat-native

查看是否安裝成功:
# rpm -qa tomcat-native
tomcat-native-1.1.30-1.el7.x86_64


配置相關的全局變量:
# vi /etc/profile
添加:export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/apr/lib
# source /etc/profile


5、重啓Tomcat,看看是否可以成功使用APR
如果一切正常:
APR啓動:
[main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["http-apr-18080"]
[main] org.apache.catalina.startup.Catalina.start Server startup in 13617 ms


6.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)。



非常好的:http://blog.chinaunix.net/uid-26204366-id-3896703.html

發佈了20 篇原創文章 · 獲贊 5 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章