Tomcat服務器優化


Tomcat內存溢出(java.lang.OutOfMemoryError: PermGen space)的問題經常會在開發中遇到,面試中也有會問到的時候,所以我決定要記一下。

首先,優化tomcat我給出三個方向:

a) 內存優化:主要是對Tomcat啟動參數進行優化,我們可以在Tomcat啟動腳本中修改它的最大內存數等等。

b) 線程數優化:Tomcat的並發連接參數,主要在Tomcat配置文件中server.xml中配置,比如修改最小空閑連接線程數,用於提高系統處理性能等等。

c) 優化緩存:打開壓縮功能,修改參數,比如壓縮的輸出內容大小默認為2KB,可以適當的修改。

針對第一點,我們需要了解以下6個參數:

1:-Xms 堆空間初始大小

2:-Xmx 堆空間最大數值

3:-Xmn 年輕代的堆大小

4:-Xss   每個線程堆大小

5:-XX: PermSize 內存永久保留區域 

6:-XX:MaxPermSize 內存最大永久保留區域

這幾個參數都是在Tomcat 啟動腳本(bin/catalina.bat)中進行配置的,一般開發環境配置時我們就會預先配置好。只要把以下代碼加入文件中,並且重啟Tomcat即可。

JAVA_OPTS="-Xms2048m -Xmx2048m -Xmn1024m -Xss1024K -XX:PermSize=128m -XX:MaxPermSize=512m"(具體數值按公司服務器大小以及實際自行配置)

第二第三點合在一起優化也是修改Tomcat的配置文件server.xml。初學者一般使用這個文件都是為了修改端口號。

我們打開server.xml找到Connector 標簽項,可以看到默認配置如下:

1 <Connector port="8080" protocol="HTTP/1.1"  
2  connectionTimeout="20000"  
3  redirectPort="8443" /> 

其中port代表服務端口;protocol代表協議類型;connectionTimeout代表連接超時時間,單位為毫秒;redirectPort代表安全通信(https)轉發端口,一般配置成443。

我們需要調整連接器connector的並發處理能力,比如這樣:

 1 <Connector port="8080"
 2   protocol="HTTP/1.1"
 3   maxHttpHeaderSize="8192"
 4   maxThreads="1000"
 5   minSpareThreads="100"
 6   maxSpareThreads="1000"
 7   minProcessors="100"
 8   maxProcessors="1000"
 9   enableLookups="false"
10   compression="on"
11   compressionMinSize="2048"
12   compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain"
13   connectionTimeout="20000"
14   URIEncoding="utf-8"
15   acceptCount="1000"
16   redirectPort="8443"
17   disableUploadTimeout="true"/>

參數說明:

  maxThreads 客戶請求最大線程數 
  minSpareThreads Tomcat初始化時創建的 socket 線程數 
  maxSpareThreads Tomcat連接器的最大空閑 socket 線程數 
  enableLookups 若設為true, 則支持域名解析,可把 ip 地址解析為主機名 
  redirectPort 在需要基於安全通道的場合,把客戶請求轉發到基於SSL 的 redirectPort 端口 
  acceptAccount 監聽端口隊列最大數,滿了之后客戶請求會被拒絕(不能小於maxSpareThreads ) 
  minProcessors 服務器創建時的最小處理線程數 
  maxProcessors 服務器同時最大處理線程數 
  URIEncoding URL統一編碼
  compression 打開壓縮功能 
  compressionMinSize 啟用壓縮的輸出內容大小,這里面默認為2KB 
  compressableMimeType 壓縮類型 
  connectionTimeout 定義建立客戶連接超時的時間. 如果為 -1, 表示不限制建立客戶連接的時間

推薦一篇好文章:http://blog.csdn.net/kally_wang/article/details/74989885  目前我還是有點看不大明白的,還得學習下,其中提到了線程池,我在想這和數據庫連接池是應該有異曲同工之處。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM