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操作系统网络内核优化

聊一聊TCP协议的TIME_WAIT与性能优化

TIME_WAIT过多

如何解决 linux socket TIME_WAIT 过多造成的问题(SYNACKFINMSLRST含义)

Linux下TIME_WAIT连接优化内核参数tcp_tw_reuse与tcp_tw_recycle区别与联系浅析

nginx time_wait 较多优化