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 目前我還是有點看不大明白的,還得學習下,其中提到了線程池,我在想這和數據庫連接池是應該有異曲同工之處。