TCP之选项TCP_KETEPALIVE

TCP之选项TCP_KETEPALIVE
 
KEEPALIVE机制,是TCP协议规定的TCP层(非应用层业务代码实现的)检测TCP本端到对方主机的TCP连接的连通性的行为。避免服务器在客户端出现各种不良状况时无法感知,而永远等在这条TCP连接上。
 
该选项可以设置这个检测行为的细节,如下代码所示:
int keepAlive = 1;    // 非0值,开启keepalive属性
int keepIdle = 60;    // 如该连接在60秒内没有任何数据往来,则进行此TCP层的探测
int keepInterval = 5; // 探测发包间隔为5秒
int keepCount = 3;        // 尝试探测的次数.如果第1次探测包就收到响应了,则后2次的不再发
setsockopt(sockfd, SOL_SOCKET, SO_KEEPALIVE, (void *)&keepAlive, sizeof(keepAlive));
setsockopt(sockfd, SOL_TCP, TCP_KEEPIDLE, (void*)&keepIdle, sizeof(keepIdle));
setsockopt(sockfd, SOL_TCP, TCP_KEEPINTVL, (void *)&keepInterval, sizeof(keepInterval));
setsockopt(sockfd, SOL_TCP, TCP_KEEPCNT, (void *)&keepCount, sizeof(keepCount));
 
设置该选项后,如果60秒内在此套接口所对应连接的任一方向都没有数据交换,TCP层就自动给对方发一个保活探测分节(keepalive probe)。这是一个对方必须响应的TCP分节。它会导致以下三种情况:
    对方接收一切正常:以期望的ACK响应。60秒后,TCP将重新开始下一轮探测。
    对方已崩溃且已重新启动:以RST响应。套接口的待处理错误被置为ECONNRESET。
    对方无任何响应:比如客户端那边已经断网,或者客户端直接死机。以设定的时间间隔尝试3次,无响应就放弃。套接口的待处理错误被置为ETIMEOUT。
 
全局设置可更改/etc/sysctl.conf,加上:
net.ipv4.tcp_keepalive_intvl = 5
net.ipv4.tcp_keepalive_probes = 3
net.ipv4.tcp_keepalive_time = 60
 
在程序中表现为:
阻塞模型下,当TCP层检测到对端socket不再可用时,内核无法主动通知应用层出错,只有应用层主动调用read()或者write()这样的IO 系统调用时,内核才会利用出错来通知应用层。
非阻塞模型下,select或者epoll会返回sockfd可读,应用层对其进行读取时,read()会报错。
 
一点经验:
实际上我们在做服务器程序的时候,对客户端的保活探测基本上不依赖于这个TCP层的keepalive探测机制。
而是我们自己做一套应用层的请求应答消息,在应用层实现这样一个功能。
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: tcp_max_syn_backlog 是一个 TCP 协议的参数,用于控制 TCP SYN 连接请求的最大队列长度。当有大量的客户端同时向服务器发起连接请求时,服务器可能会出现 SYN 队列溢出的情况,导致客户端连接失败。通过调整 tcp_max_syn_backlog 参数,可以增加 TCP SYN 队列的最大长度,从而提高服务器的连接请求处理能力。 在 Linux 系统中,tcp_max_syn_backlog 默认值为 1024。可以通过修改 /proc/sys/net/ipv4/tcp_max_syn_backlog 文件来调整该参数的值。但需要注意的是,过大的 tcp_max_syn_backlog 值会占用过多的系统资源,从而影响系统的性能表现。 ### 回答2: tcp_max_syn_backlog是TCP协议中一个参数,用于控制SYN队列的最大长度。SYN队列存储了正在与服务器建立连接的客户端请求,当服务器接收到客户端的SYN请求时,会将其放入SYN队列中。tcp_max_syn_backlog参数的作用就是控制SYN队列的最大长度,当SYN队列已满时,服务器将无法接受新的连接请求。 如果tcp_max_syn_backlog值设置过小,当服务器接收到大量的客户端连接请求时,有可能会导致SYN队列溢出,从而导致新的连接请求被丢弃,客户端无法与服务器建立连接。在高并发的网络环境下,适当增大tcp_max_syn_backlog值可以提高服务器的处理能力,减少客户端连接丢失的概率。 然而,设置过大的tcp_max_syn_backlog值也会有一些问题。首先,SYN队列的长度是有限的,如果设置过大,会占用服务器的内存资源。其次,如果服务器无法及时处理SYN队列中的请求,会造成客户端连接的延迟增加。 因此,在调整tcp_max_syn_backlog值时,需要根据服务器的实际情况进行综合考虑。一般来说,如果服务器处于高并发的环境中,可以适当增大tcp_max_syn_backlog值。而对于低并发的场景,则可以适当减小tcp_max_syn_backlog值,以节省服务器资源。为了保证服务器的稳定性和性能,在调整tcp_max_syn_backlog值时,还需要结合服务器的硬件配置、网络带宽以及预计的连接请求负载等因素进行综合评估和测试。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值