在參與搜人項目時,遇到tomcat假死的問題。
當時情況:
1、ps tomcat正在運行
2、用netstat 查看8080連接情況,有大量的close-wait,還有一些等待連接的狀態
3、查看服務器的使用情況,沒有過多的消耗內存和CPU
4、重新加載界面,沒有報錯,只是顯示加載失敗
5、加載時看到tomcat 日志報錯 out of memary
在網上查看資料,問題得到解決
服務器配置:linux+tomcat
現象:Linux服務器沒有崩,有瀏覽器中訪問頁面,出現無法訪問的情況,沒有報4xx或5xx錯誤(假死),並且重啟tomcat后,恢復正常。
原因:tomcat默認最大連接數(線程數)200個,默認每一個連接的生命周期2小時(7200秒),tomcat使用http 1.1協議,而http1.1默認是長連接。tomcat接受處理完請求后,socket沒有主動關閉,因此如果在2小時內,請求數超過200個,服務器就會出現上述假死現象。
解決方案1:及時斷開socket
解決方案2:修改tomcat配置文件,修改最大連接數(增大)
修改server.xml配置文件,Connector節點中增加acceptCount和maxThreads這兩個屬性的值,並且使acceptCount大於等於maxThreads:
protocol="org.apache.coyote.http11.Http11NioProtocol"
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" acceptCount="500" maxThreads="400" />
解決方案3:修改linux的TCP超時時間(socket生命周期)限制
1
2
3
4
5
6
7
8
9
10
11
12
|
vi
/etc/sysctl
.conf
# Decrease the time default value for tcp_fin_timeout connection
net.ipv4.tcp_fin_timeout = 30
# Decrease the time default value for tcp_keepalive_time connection
net.ipv4.tcp_keepalive_time = 1800
# 探測次數
net.ipv4.tcp_keepalive_probes=2
# 探測間隔秒數
net.ipv4.tcp_keepalive_intvl=2
編輯完
/etc/sysctl
.conf,要重啟network 才會生效
[root@temp /]
# /etc/rc.d/init.d/network restart
|