这个问题,大家在使用php redis之后肯定都会遇到。所以本菜本着虚心求教的原则,又在网上四处求教。得到的答案,无非是以下两种:
1、redis没有主动close。
事后发现,这个答案纯属以讹传讹,胡说八道。
2、配置/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 = 20
关于这个方案,虽然比较靠谱,但没完全正中靶心。执行/sbin/sysctl -p之后,发现timewait状态的连接没有改善。
经过一番查找,终于本菜终于找到了原因,解决方案的配置如下:
/etc/sysctl.conf
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.tcp_timestamps = 1
net.ipv4.tcp_fin_timeout = 20
配置完成之后,执行/sbin/sysctl -p,再次运行redis,问题解决。
资料参考:
http://www.2cto.com/net/201503/381132.html 服务器tcp连接timewait过多优化及详细分析
|