linux tcp 长连接保活的问题

本文介绍了在遇到长连接被异常断开的问题时,如何通过检查和调整TCP保活参数来解决问题。文中详细解释了三个关键参数tcp_keepalive_intvl、tcp_keepalive_probes和tcp_keepalive_time的作用,并给出了正确的配置方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在实验室中有一台机器,总是不正常,客户端与它保持长连接,只要时间稍微长一点无操作时,就会被断开,所以联想到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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值