Ubuntu20下C/C++编程开启TCP KeepAlive

1、在linux下,测试tcp保活,可以使用tcp自带keepalive功能。

2、几个重要参数:

tcp_keepalive_time:对端在指定时间内没有数据传输,则向对端发送一个keepalive packet,单位:秒
tcp_keepalive_intvl:向对端发送了一个keepalive packet,如果对端无响应,则等待tcp_keepalive_intvl秒后再次发送一个keepalive packet
tcp_keepalive_probes:向对端发送一个keepalive packet,如果对端没有响应,重发的次数,如果tcp_keepalive_probes次数后,对端都没有响应,则表示这个socket已经断开,系统会差生连接断开事件,本地就可以关闭这个socket上连接。

3、修改三个参数的系统默认值

上述三个参数当前配置可以在 /proc/sys/net/ipv4查看

可以使用cat查看具体配置,比如

  • 全局设置:可更改/etc/sysctl.conf,加上:

sudo vim /etc/sysctl.conf

net.ipv4.tcp_keepalive_intvl = 20

net.ipv4.tcp_keepalive_probes = 3

net.ipv4.tcp_keepalive_time = 60

保存:wq

重启系统:sudo reboot

4、编程设置keeepalive:

cpp 复制代码
#include <netinet/tcp.h>


 /*开始设置保活机制*/

int val = 1;

if (setsockopt(nc->sock, SOL_SOCKET, SO_KEEPALIVE, &val, sizeof val) != 0)
{

    perror("Set SO_KEEPALIVE fail");

}

/* Default settings are more or less garbage, with the keepalive time

* set to 7200 by default on Linux. Modify settings to make the feature

* actually useful. */

/* Send first probe after interval. */

val = 10;

if (setsockopt(nc->sock, IPPROTO_TCP, TCP_KEEPIDLE, &val, sizeof(val)) < 0)
{

    perror("Set TCP_KEEPIDLE fail");

}

/* Send next probes after the specified interval. Note that we set the

* delay as interval / 3, as we send three probes before detecting

* an error (see the next setsockopt call). */

val = 3;

if (setsockopt(nc->sock, IPPROTO_TCP, TCP_KEEPINTVL, &val, sizeof(val)) < 0)
{

    perror("Set TCP_KEEPINTVL fail");

}

/* Consider the socket in error state after three we send three ACK

* probes without getting a reply. */

val = 3;

if (setsockopt(nc->sock, IPPROTO_TCP, TCP_KEEPCNT, &val, sizeof(val)) < 0)
{

        perror("Set TCP_KEEPCNT fail");

}

5、查看通讯情况,打开wireshark,在过滤器输入设置keepalive的Ip格式为:ip.addr==xxx.xxx.xxx.xxx

上图可以看到,每隔10秒钟发送了一个keepalive packet.因为上述代码中,我们设置的TCP_KEEPIDLE=10

相关推荐
国科安芯9 小时前
多输出电压条件下同步整流效率测试与优化
网络·单片机·嵌入式硬件·安全
想唱rap10 小时前
Linux开发工具(4)
linux·运维·服务器·开发语言·算法
东方隐侠安全团队-千里10 小时前
第3节 RSA算法开启公钥加密时代
网络·人工智能·算法
泷羽Sec-静安11 小时前
Less-9 GET-Blind-Time based-Single Quotes
服务器·前端·数据库·sql·web安全·less
njnu@liyong11 小时前
HTTP-http是什么?
网络·网络协议·http
李宥小哥11 小时前
结构型设计模式2
网络·数据库·设计模式
xian_wwq11 小时前
【学习笔记】《孙子兵法》与网络安全
网络·笔记·学习
猫头虎12 小时前
永久免费白嫖多个域名,一键托管Cloudflare,免费申请SSL加密证书,轻松建站、搭建线路伪装
服务器·开发语言·网络·数据库·python·网络协议·ssl
攒钱植发12 小时前
嵌入式Linux——“大扳手”与“小螺丝”:为什么不该用信号量(Semaphore)去模拟“完成量”(Completion)
linux·服务器·c语言
德迅云安全杨德俊12 小时前
服务器为何成为网络攻击的“重灾区“?
网络·安全·web安全·ddos