通过ss -s 命令,可以看到服务器的timewait状态特别多。
- [root@tvreport231 ~]# ss -s
- Total: 103 (kernel 256)
- TCP: 48666 (estab 22, closed 48624, orphaned 7, synrecv 0, timewait 48623/0), ports 18
netstat也是可以看到的,但是需要添加 -a参数才能看到time_wait状态。
下面的命令复杂点,但是可以看到更多信息:
- [root@tvreport231 ~]# netstat -an|awk '/tcp/ {print $6}'|sort|uniq -c
- 11 ESTABLISHED
- 1 FIN_WAIT1
- 11 LISTEN
- 41300 TIME_WAIT
解决方法:
一种解决方法是利用sysctl在运行时修改内核参数
直接在文件/etc/sysctl.conf末尾添加两行设置:
- net.ipv4.tcp_tw_reuse=1
- net.ipv4.tcp_tw_recycle=1
然后调用sysctl -p加载之,果然效果明显
不过据说这样会影响内网用户。