在实验室中有一台机器,总是不正常,客户端与它保持长连接,只要时间稍微长一点无操作时,就会被断开,所以联想到tcp保活的问题,使用sysctl -a | grep tcp_keep查看参数,得到:

net.ipv4.tcp_keepalive_intvl = 3

net.ipv4.tcp_keepalive_probes = 2
net.ipv4.tcp_keepalive_time = 5

这个配置很不正常,默认一般是75、9、7200。

tcp_keepalive_intvl – INTEGER

在keepalive探测包开始后,探测包每隔多长时间发送一次。

默认值: 75s

tcp_keepalive_probes – INTEGER

在决定连接被断掉,通知应用层前,发送keepalive探测包的次数。

默认值: 9

tcp_keepalive_time – INTEGER

在连接被标记为需要keepalive后,最后数据被发送和第一个keepalive探测包的间隔。

默认值: 2hours

根据上述参数来看,如果一个client发送一个标记为keepalive的包后,如果断开了,服务端需要7200s+9*75s=7875s后,连接才释放掉。

修改上面的配置,直接修改/etc/sysctl.conf文件,找到上面几个参数,修改它,然后:

sysctl -p

sysctl -w net.ipv4.route.flush=1

让配置生效。

service network restart

重启network
————————————————
版权声明:本文为CSDN博主「flyinmind」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/flyinmind/java/article/details/8717636

发表评论

邮箱地址不会被公开。 必填项已用*标注