有谁知道 Linux 是否支持传出连接上的保持活动套接字选项?
我建立了一个带有保持活动选项的传出连接,但 netstat --timers 显示(我假设计时器已关闭):
tcp 0 0 localhost.localdomain:44307 172.16.0.15:2717 ESTABLISHED off (0.00/0/0)
应用相同套接字选项的传入连接显示:
tcp 0 0 172.16.0.3:8585 localhost.localdomain:21527 ESTABLISHED keepalive (29.26/0/0)
我希望能看到套接字选项,但 ss 和 lsof 都没有显示它们。
答案1
首先,您需要确保您的系统上已启用 TCP keepalive。您可以像这样检查默认设置:
# sysctl net.ipv4.tcp_keepalive_time net.ipv4.tcp_keepalive_probes net.ipv4.tcp_keepalive_intvl
net.ipv4.tcp_keepalive_time = 7200
net.ipv4.tcp_keepalive_probes = 9
net.ipv4.tcp_keepalive_intvl = 75
然后确保在代码中正确设置它。它应该看起来像这样:
int optval = 1;
if (setsockopt(s, SOL_SOCKET, SO_KEEPALIVE, &optval, sizeof(optval)) < 0) {
perror("setsockopt()");
close(s);
exit(EXIT_FAILURE);
}
在我的系统上,当我使用上述代码在两侧设置 SO_KEEPALIVE 时,我看到:
tcp 0 0 127.0.0.1:48591 127.0.0.1:5555 ESTABLISHED keepalive (6958.37/0/0)
tcp 0 0 127.0.0.1:5555 127.0.0.1:48591 ESTABLISHED keepalive (6958.37/0/0)
然后我用 wireshark 验证了 keepaliveNOP
已被发送。
更多详情请参阅TCP 保活方法。
答案2
客户端 sysctl 设置:
sudo /sbin/sysctl -a|grep keep
net.ipv4.tcp_keepalive_time = 20
net.ipv4.tcp_keepalive_probes = 1
net.ipv4.tcp_keepalive_intvl = 1
客户端保持tcpdump:
sudo /usr/sbin/tcpdump -nn -vv -i bond0 tcp and host 10.201.126.72 and port 8001
tcpdump: listening on bond0, link-type EN10MB (Ethernet), capture size 65535 bytes
但没有抓到任何包,说明tcp_keepalive_time不起作用