`
xixinfei
  • 浏览: 414819 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

长连接和Keepalive详解

    博客分类:
  • web
阅读更多

TCP协议中有长连接和短连接之分。短连接在数据包发送完成后就会自己断开,长连接在发包完毕后,会在一定的时间内保持连接,即我们通常所说的Keepalive(存活定时器)功能。
默认的Keepalive超时需要7,200,000 milliseconds,即2小时,探测次数为5次。它的功效和用户自己实现的心跳机制是一样的。开启Keepalive功能需要消耗额外的宽带和流量,尽管这微不足道,但在按流量计费的环境下增加了费用,另一方面,Keepalive设置不合理时可能会因为短暂的网络波动而断开健康的TCP连接。

keepalive并不是TCP规范的一部分。在Host Requirements RFC罗列有不使用它的三个理由:(1)在短暂的故障期间,它们可能引起一个良好连接(good connection)被释放(dropped),(2)它们消费了不必要的宽带,(3)在以数据包计费的互联网上它们(额外)花费金钱。然而,在许多的实现中提供了存活定时器。

 

一些服务器应用程序可能代表客户端占用资源,它们需要知道客户端主机是否崩溃。存活定时器可以为这些应用程序提供探测服务。Telnet服务器和Rlogin服务器的许多版本都默认提供存活选项。

 

个人计算机用户使用TCP/IP协议通过Telnet登录一台主机,这是能够说明需要使用存活定时器的一个常用例子。如果某个用户在使用结束时只是关掉了电源,而没有注销(log off),那么他就留下了一个半打开(half-open)的连接。如果客户端消失,留给了服务器端半打开的连接,并且服务器又在等待客户端的数据,那么等待将永远持续下去。存活特征的目的就是在服务器端检测这种半打开连接。

 

也可以在客户端设置存活器选项,且没有不允许这样做的理由,但通常设置在服务器。如果连接两端都需要探测对方是否消失,那么就可以在两端同时设置(比如NFS)。


keepalive工作原理:

 

若在一个给定连接上,两小时之内无任何活动,服务器便向客户端发送一个探测段。(我们将在下面的例子中看到探测段的样子。)客户端主机必须是下列四种状态之一:

 

1)客户端主机依旧活跃(up)运行,并且从服务器可到达。从客户端TCP的正常响应,服务器知道对方仍然活跃。服务器的TCP为接下来的两小时复位存活定时器,如果在这两个小时到期之前,连接上发生应用程序的通信,则定时器重新为往下的两小时复位,并且接着交换数据。

 

2)客户端已经崩溃,或者已经关闭(down),或者正在重启过程中。在这两种情况下,它的TCP都不会响应。服务器没有收到对其发出探测的响应,并且在75秒之后超时。服务器将总共发送10个这样的探测,每个探测75秒。如果没有收到一个响应,它就认为客户端主机已经关闭并终止连接。

 

3)客户端曾经崩溃,但已经重启。这种情况下,服务器将会收到对其存活探测的响应,但该响应是一个复位,从而引起服务器对连接的终止。

 

4)客户端主机活跃运行,但从服务器不可到达。这与状态2类似,因为TCP无法区别它们两个。它所能表明的仅是未收到对其探测的回复。

 

 

 

服务器不必担心客户端主机被关闭然后重启的情况(这里指的是操作员执行的正常关闭,而不是主机的崩溃)。当系统被操作员关闭时,所有的应用程序进程(也就是客户端进程)都将被终止,客户端TCP会在连接上发送一个FIN。收到这个FIN后,服务器TCP向服务器进程报告一个文件结束,以允许服务器检测这种状态。

 

在第一种状态下,服务器应用程序不知道存活探测是否发生。凡事都是由TCP层处理的,存活探测对应用程序透明,直到后面234三种状态发生。在这三种状态下,通过服务器的TCP,返回给服务器应用程序错误信息。(通常服务器向网络发出一个读请求,等待客户端的数据。如果存活特征返回一个错误信息,则将该信息作为读操作的返回值返回给服务器。)在状态2,错误信息类似于“连接超时”。状态3则为“连接被对方复位”。第四种状态看起来像连接超时,或者根据是否收到与该连接相关的ICMP错误信息,而可能返回其它的错误信息。

linux内核包含对keepalive的支持。其中使用了三个参数:tcp_keepalive_time(开启keepalive的闲置时 长)tcp_keepalive_intvlkeepalive探测包的发送间隔)和tcp_keepalive_probes(如果对方不予应答,探测包的发送次数);在liunx中,keepalive是一个开关选项,可以通过函数来使能。具体地说,可以使用以下代码:
setsockopt(rs, SOL_SOCKET, SO_KEEPALIVE, (void *)&keepAlive, sizeof(keepAlive));

 

 

 

tcp检测到对端socket不再可用时(不能发出探测包,或探测包没有收到ACK的响应包),select会返回socket可读,并且在recv时返回-1,同时置上errnoETIMEDOUT。此时TCP的状态是断开的。



keepalive参数设置代码如下:

// 开启KeepAlive
BOOL bKeepAlive = TRUE;
int nRet = ::setsockopt(socket_handle, SOL_SOCKET, SO_KEEPALIVE, (char*)&bKeepAlive, sizeof
(bKeepAlive));
if (nRet ==
SOCKET_ERROR)
{
return
FALSE;
}

// 设置KeepAlive参数

tcp_keepalive alive_in = {0};
tcp_keepalive alive_out
= {0
};
alive_in.keepalivetime
=5000; // 开始首次KeepAlive探测前的TCP空闭时间

alive_in.keepaliveinterval =1000; // 两次KeepAlive探测间的时间间隔
alive_in.onoff = TRUE;
unsigned
long ulBytesReturn =0
;
nRet
= WSAIoctl(socket_handle, SIO_KEEPALIVE_VALS, &alive_in, sizeof
(alive_in),
&alive_out, sizeof(alive_out), &
ulBytesReturn, NULL, NULL);
if (nRet ==
SOCKET_ERROR)
{
return
FALSE;
}


开启Keepalive选项之后,对于使用IOCP模型的服务器端程序来说,一旦检测到连接断开,GetQueuedCompletionStatus函 数将立即返回FALSE,使得服务器端能及时清除该连接、释放该连接相关的资源。对于使用select模型的客户端来说,连接断开被探测到时,以recv 目的阻塞在socket上的select方法将立即返回SOCKET_ERROR,从而得知连接已失效,客户端程序便有机会及时执行清除工作、提醒用户或 重新连接。

TCP连接非正常断开的检测(KeepAlive探测)

 

此处的”非正常断开”指TCP连接不是以优雅的方式断开,如网线故障等物理链路的原因,还有突然主机断电等原因

 

有两种方法可以检测:1.TCP连接双方定时发握手消息2.利用TCP协议栈中的KeepAlive探测

第二种方法简单可靠,只需对TCP连接两个Socket设定KeepAlive探测。


在windows下使用,要包含MSTcpIP.h的头文件。点击下面的链接即可下载这个文件
MSTcpIP

备注:长连接虽好,但是比较好用但是占用系统资源比较大。个人建议如无特殊需要,用自己的心跳包机制最好

长连接和Keepalive详解

分享到:
评论

相关推荐

    springboot-keepalive设置测试

    在这个“springboot-keepalive设置测试”项目中,我们将关注的是如何在Spring Boot应用中配置和测试HTTP长连接(keepalive)功能,以优化服务器与客户端之间的通信效率。 HTTP长连接,也被称为持久连接,允许TCP...

    GRE隧道keepalive的说明

    ### GRE隧道Keepalive详解 #### 前言 随着网络技术的发展,GRE(Generic Routing Encapsulation)隧道作为一种广泛应用于互联网中的技术,对于实现不同网络之间的通信具有重要意义。然而,在实际应用过程中,如何...

    HTTP协议Keep-Alive模式详解

    Keep-Alive 模式使得客户端和服务器端可以多次使用同一个连接,避免了每个请求都新建一个连接的开销,从而提高了性能。 二、启用 Keep-Alive 的优点 启用 Keep-Alive 模式可以提高性能,避免了每个请求都新建一个...

    keepalive1.1.17.zip

    3. **启动和监控**: 启动Keepalive服务,它将定期检查主从服务器之间的连接状态和复制延迟。如果发现异常,Keepalive可以发送报警或自动执行故障切换。 4. **报警机制**: Keepalive可以根据配置设置不同的报警阈值...

    keepalive中文文档

    **Keepalive详解** `Keepalive`是网络通信中一个重要的概念,它主要用于维持TCP连接的活跃状态。在TCP协议中,一旦连接建立,双方就可以在连接上无限制地发送数据,直到一方主动关闭连接。然而,在长时间无数据传输...

    keepalive的安装包

    在计算机网络领域,Keepalive是一项重要的技术,它主要用于保持网络连接的活跃状态,防止因长时间无数据传输导致的连接超时或断开。Keepalive机制通常应用于TCP(传输控制协议)连接,确保网络会话在服务器和客户端...

    详解Nginx中HTTP的keepalive相关配置

    比如,如果发现大量的短连接请求频繁地创建和销毁TCP连接,可以通过增加keepalive_timeout的时间来减少连接的建立次数。 文章中还提到了通过脚本模拟长请求,使用tcpdump工具捕获TCP交互过程,以此来分析keepalive_...

    Nginx反向代理实现支持长连接详解

    Nginx与前端的连接默认为长连接,一个用户跟Nginx建立连接之后,通过这个长连接发送多个请求。如果Nginx只是作为reverse proxy的话,可能一个用户连接就需要多个向后端的短连接。如果后端的服务器(源站或是缓存...

    Netty空闲检测&Keepalive.pdf

    ### Netty空闲检测与Keepalive机制详解 #### 一、引言 在现代网络通信中,客户端与服务器之间的连接管理至关重要。为了确保连接的有效性和稳定性,Netty 提供了两种重要的机制:**空闲检测** 和 **Keepalive**。这...

    CurlmultiThread.rar

    《使用libCurl进行多线程HTTP连接:长连接与短连接详解》 在现代的网络编程中,高效地处理HTTP请求是至关重要的。libCurl是一个强大的、跨平台的库,它允许开发者轻松地实现各种网络协议,包括HTTP、HTTPS等。本篇...

    WDT.zip_WDIOC_KEEPALIVE_wdt

    《Linux平台下的看门狗驱动——WDIOC KEEPALIVE与WDT详解》 在嵌入式系统和服务器领域,看门狗定时器(Watchdog Timer, WDT)是一种至关重要的功能,它能确保系统的稳定性和可靠性。在Linux操作系统中,看门狗驱动...

    CLOSE_WAIT错误详解

    4. **使用Keepalive机制**:启用TCP Keepalive选项,周期性发送探测报文,以便在无数据交换的情况下检测连接是否还活跃,从而及时关闭无效连接。 在实际应用中,CLOSE_WAIT错误可能会导致服务器性能下降,甚至完全...

    centos7-lvs+keepalive部署

    ### CentOS 7 上 LVS+Keepalived 部署详解 #### 一、环境准备与软件安装 根据提供的部分内容可以看出,本教程旨在演示如何在 CentOS 7 系统上安装配置 LVS(Linux Virtual Server)及 Keepalived 服务,以实现...

    apache 配置中文详解

    Apache 配置文件详解 Apache 配置文件是 Apache 服务器的核心组件之一,它控制着服务器的行为和性能。配置文件的正确设置对服务器的性能和安全性有着至关重要的影响。在这篇文章中,我们将深入探讨 Apache 配置文件...

    Time-wait详解和解决方案.docx

    ### Time-wait详解和解决方案 #### 一、产生原因 在TCP协议中,当一个连接关闭时,会经历四个步骤的交互(通常称为四次挥手)以确保双方都已经停止发送数据并确认对方也已停止接收数据。在这个过程中,主动发起...

    apache配置文件详解

    - **说明**: KeepAlive用于启用HTTP的持久连接特性,这是对HTTP/1.0和HTTP/1.1标准中长连接特性的扩展。持久连接能够在一个TCP连接中执行多个请求,这对于包含大量图像等资源的HTML页面尤其有益,可以提高加载速度...

    APACHE配置文件中文详解

    `MaxKeepAliveRequests`定义了每个连接能处理的最大请求数,`KeepAliveTimeout`是两个连续请求之间服务器等待的最长时间。 在Windows环境下,Apache使用子进程处理请求,`MaxRequestsPerChild`设置每个子进程在结束...

    Apache 的 httpd.conf 详解

    ### Apache的httpd.conf配置详解 #### 一、概述 `httpd.conf` 是Apache Web服务器的核心配置文件,它控制着服务器的行为与功能。通过合理地配置这些参数,可以极大地提高服务器的安全性、性能和可扩展性。下面将对...

    Tomcat配置详解

    2. **`keepAliveTimeout`**: 长连接的最大保持时间,单位为毫秒。例如设置为15秒。 3. **`maxKeepAliveRequests`**: 最大长连接个数。设置为1表示禁用,-1表示不限制个数,默认为100。根据实际情况调整。 4. **`...

Global site tag (gtag.js) - Google Analytics