linux 服务器优化 --TIME_WAIT 问题
Posted Sinsen柳
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux 服务器优化 --TIME_WAIT 问题相关的知识,希望对你有一定的参考价值。
linux 服务器优化 --TIME_WAIT 问题:
检查服务器TIME_WAIT 问题:
netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}‘ 返回: TIME_WAIT 41735 CLOSE_WAIT 145 FIN_WAIT2 3 ESTABLISHED 413
优化配置:
sudo nano /etc/sysctl.conf 添加下面内容: net.ipv4.tcp_syncookies = 1 net.ipv4.tcp_tw_reuse = 1 net.ipv4.tcp_tw_recycle = 1 net.ipv4.tcp_fin_timeout = 30
参数生效:
/sbin/sysctl -p 修改说明: net.ipv4.tcp_syncookies = 1 表示开启SYN cookies。当出现SYN等待队列溢出时,启用cookies来处理,可防范少量SYN攻击,默认为0,表示关闭; net.ipv4.tcp_tw_reuse = 1 表示开启重用。允许将TIME-WAIT sockets重新用于新的TCP连接,默认为0,表示关闭; net.ipv4.tcp_tw_recycle = 1 表示开启TCP连接中TIME-WAIT sockets的快速回收,默认为0,表示关闭。 net.ipv4.tcp_fin_timeout 修改系統默认的 TIMEOUT 时间
TIME_WAIT 状态产生:
客户端与服务器端建立TCP/IP连接后关闭SOCKET后,服务器端连接的端口状态为TIME_WAIT
主动关闭的一方在发送最后一个 ack 后就会进入 TIME_WAIT 状态 停留2MSL(max segment lifetime)时间
这个是TCP/IP必不可少的
以上是关于linux 服务器优化 --TIME_WAIT 问题的主要内容,如果未能解决你的问题,请参考以下文章
如何解决 linux socket TIME_WAIT 过多造成的问题(SYNACKFINMSLRST含义)