`
隐形的翅膀
  • 浏览: 496613 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

TCP心跳机制

 
阅读更多
心跳的两种方式

1) 应用层面的心跳机制
   好处是可以扩展可携带的消息

2) TCP协议自带的保活功能
   打开keep-alive功能即可. 具体属性也可以通过API设定.

如何使用Keep-alive
int keepAlive = 1;   // 开启keepalive属性. 缺省值: 0(关闭)  
int keepIdle = 60;   // 如果在60秒内没有任何数据交互,则进行探测. 缺省值:7200(s)  
int keepInterval = 5;   // 探测时发探测包的时间间隔为5秒. 缺省值:75(s)  
int keepCount = 2;   // 探测重试的次数. 全部超时则认定连接失效..缺省值:9(次)  
setsockopt(s, SOL_SOCKET, SO_KEEPALIVE, (void*)&keepAlive, sizeof(keepAlive));  
setsockopt(s, SOL_TCP, TCP_KEEPIDLE, (void*)&keepIdle, sizeof(keepIdle));  
setsockopt(s, SOL_TCP, TCP_KEEPINTVL, (void*)&keepInterval, sizeof(keepInterval));  
setsockopt(s, SOL_TCP, TCP_KEEPCNT, (void*)&keepCount, sizeof(keepCount));



修改配置文件, 对整个系统所有的socket有效.

我们可以用cat命令查看到系统中这几个默认的值.

#cat /proc/sys/net/ipv4/tcp_keepalive_time  7200  

#cat /proc/sys/net/ipv4/tcp_keepalive_intvl  75  

#cat /proc/sys/net/ipv4/tcp_keepalive_probes  9


修改它们:

#echo 60 > /proc/sys/net/ipv4/tcp_keepalive_time  

#echo 5 > /proc/sys/net/ipv4/tcp_keepalive_intvl  

#echo 3 > /proc/sys/net/ipv4/tcp_keepalive_probes 



对于Win2K/XP/2003,可以从下面的注册表项找到影响整个系统所有连接的keepalive参数:
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters]
“KeepAliveTime”=dword:006ddd00
“KeepAliveInterval”=dword:000003e8
“MaxDataRetries”=”5″
 

  对于实用程序来说,2小时的空闲时间太长。因此,我们需要手工开启Keepalive功能并设置合理的Keepalive参数。在XP和WIN2003系统上,可以针对单独的socket来设置,但是在windows 2000,不能单独设置,如果设置,那么影响是整个系统的所有socket。
分享到:
评论

相关推荐

    TCP通信心跳包源码C语言实现

    本篇将详细讲解如何使用C语言在Linux平台上实现TCP心跳包的功能,并探讨其核心原理。 TCP是一种面向连接的、可靠的传输层协议,它通过三次握手建立连接,并通过确认应答和重传机制确保数据的可靠传输。然而,在长...

    C#TCP服务端+客户端完整示例,带心跳机制.rar

    本示例重点介绍了如何使用C#实现TCP服务端和客户端的通信,同时包含了心跳机制,以确保连接的稳定性和可靠性。下面我们将详细探讨这些知识点。 首先,TCP(Transmission Control Protocol)是一种面向连接的、可靠...

    C# 实现 TCP服务端+客户端 带心跳机制.zip

    本项目“C#实现TCP服务端+客户端带心跳机制”旨在教你如何构建一个具备心跳检查功能的TCP服务器和客户端系统,确保连接的稳定性和数据的可靠性。 TCP服务端和客户端是任何基于TCP的应用程序的两个基本组成部分。...

    关于TCP心跳检测共2页.pdf.zip

    3. **TCP心跳机制** - TCP心跳检测通常通过TCP Keepalive选项实现,由TCP头部的一个可选字段控制。 - 当设置Keepalive选项时,TCP会在一定时间内(默认通常是两个小时)发送一个“心跳”数据包,即没有有效载荷的...

    C#TCP服务端+客户端(心跳机制).zip

    自带客户与服务端心跳包验证。 客户端掉线,服务器自动响应。 所有均为事件与封装完全分享。代码高度简洁。 服务端断线与重启,客户端自动重新连接。 客户端消息异常,快速响应事件。 客户端与服务端,调用DOME完全...

    C# 实现Scoket心跳机制的方法

    心跳机制可以分为两种实现方法:应用层自己实现的心跳包和TCP的KeepAlive保活机制。 应用层自己实现的心跳包是指由应用程序自己发送心跳包来检测连接是否正常。服务器在一个Timer事件中定时向客户端发送一个...

    Java实现心跳机制的方法

    心跳机制有两种实现方式,一种基于TCP自带的心跳包,TCP的SO_KEEPALIVE选项可以实现心跳机制。系统默认的默认跳帧频率为2小时,超过2小时后,本地的TCP实现会发送一个数据包给远程的Socket。如果远程Socket没有发回...

    tcp.rar_TCP 心跳_TCP心跳_tcp 心跳_心跳_心跳 TCP

    心跳机制在TCP连接中扮演着至关重要的角色。 心跳TCP,也称为TCP心跳检测或TCP Keepalive,是TCP协议的一个可选特性,它允许两个端点周期性地发送“心跳”消息,以确认连接的活跃状态。当一方长时间没有收到对方的...

    基于MFC的TCP心跳检测包

    本话题将围绕“基于MFC的TCP心跳检测包”展开,深入探讨相关知识点。 MFC(Microsoft Foundation Classes)是微软提供的一套C++库,它为Windows应用程序开发提供了丰富的类和函数,简化了Windows API的使用。在MFC...

    Server_LabviewTCP登陆_

    - 可以考虑增加心跳机制以保持连接活跃,防止长时间无数据交换导致的连接超时。 - 对于大量并发连接,可以研究多线程或多进程技术来提高服务器性能。 以上就是关于"Server_LabviewTCP登陆_"的相关知识点,涵盖了...

    TCP心跳包-定时连接检测

    TCP协议本身并不直接支持心跳包,但可以通过自定义应用层协议来模拟心跳机制。例如,客户端和服务器可以设定一个固定的间隔时间,在这个时间内发送一个特定的数据包,如果另一方在规定时间内没有回应,那么就可以...

    精品软件工具--tcp心跳检测工具库,由客户端库和服务端软件两部分组成。服务端通过心跳端口6969发送心跳请求包,客户.zip

    《TCP心跳检测工具库详解——构建稳定网络连接的利器》 在信息技术日新月异的今天,网络连接的稳定性成为了各类应用系统的核心需求之一。为了确保数据传输的可靠性,TCP(Transmission Control Protocol)心跳检测...

    Mina开源框架 心跳机制详解

    在Mina框架中,心跳机制扮演着至关重要的角色,它确保了网络连接的健康性和可靠性。心跳机制是网络通信中的一个基本概念,主要用来检测客户端与服务器之间的连接是否依然活跃,防止因网络延迟或数据包丢失导致的假死...

    Android下Tcp通信心跳实例

    为了解决这个问题,通常会在TCP连接上添加心跳机制。心跳包就是一种用来检测连接状态并维持连接活性的机制,它能在没有实际数据交换时确保连接的存活。 标题"Android下Tcp通信心跳实例"指的是在Android应用程序中...

    S7-1200 ModbusTCP通讯

    例如,设置适当的数据传输速率,防止数据冲突,以及使用TCP心跳机制来检测和恢复网络中断。 通过以上步骤,你可以实现S7-1200与S7-300 CP343-1之间的TCP通信,利用ModbusTCP协议进行数据交换,从而实现跨设备的自动...

    Java心跳包功能TCP实现

    在Java编程中,心跳包(Heartbeat Packet)是一种在网络通信中维持连接活性的重要机制,尤其在TCP协议下,心跳包可以解决长连接因网络延迟或静默而导致的连接超时问题。TCP是一种面向连接的、可靠的传输层协议,它...

    心跳机制原理及其实现

    ### 心跳机制原理及其实现 #### 一、引言 在计算机网络通信中,尤其是在采用TCP连接的客户端/服务器(Client/Server, C/S)架构的系统中,确保网络连接的有效性和稳定性至关重要。当一方正常关闭连接时,另一方可以...

    WinSock_TCP_keepalive.rar_Keepalive_tcp 心跳_心跳 C_心跳包 c+_心跳包机制

    为了解决这个问题,引入了心跳机制和TCP的Keepalive特性。 心跳机制,顾名思义,就像生物体的心跳一样,是一种定期发送小的数据包来确认连接状态的策略。心跳包可以是任何非应用层数据,但通常为空或包含简单的状态...

    node.js的TCP通信,有心跳保活

    心跳包的发送,通常有两种技术 方法1:应用层自己实现的心跳包 由应用程序自己发送心跳包来检测连接是否正常... 方法2:TCP的KeepAlive保活机制 因为要考虑到一个服务器通常会连接多个客户端,因此由用户在应用层自己实现…

    一个Socket连接管理器(心跳机制)

    以上就是关于"一个Socket连接管理器(心跳机制)"的相关知识点,涵盖了Socket的基本概念、TCP连接原理、心跳包的设计与实现、异常处理、线程管理以及性能优化等多个方面。理解并掌握这些知识点,对于构建稳定、高效的...

Global site tag (gtag.js) - Google Analytics