1.1 TCP和UDP的心跳包是用来维持长连接的

心跳包只是用来检测socket的链接状态

2.1 非阻塞情况下TCP 心跳包是否有必要建立心跳包

  需要,

  a.如果说 严格 检测掉线的话 那么不管是不是非阻塞 都需要心跳包。(主要是因为心跳比较方便),如果想保持长连接,就需要定期发送心跳包

  b.

  1). A和Z通信。实际路线可能是: A->b->c->d->...->Z。

  2). 后来,c和d有别扭,于是: A->b->c 「断X了」 d->->Z。

  3). 除非有超时机机制,否则recv函数不会知道c和d的分手的事。

3.1 TCP自带心跳包定时为2小时,是全局TCP心跳超时,会影响系统其他应用网络连接

TCP有个KeepAlive开关,打开后可以用来检测死连接。通常默认是2小时,可以自己设置。但是注意,这是TCP的全局设置。假如为了能更及时的检测出断开的连接,把tcp_keepalive_timetcp_keepalive_intvl的时间改小(参考:Link),该机器上所有应用程序的KeepAlive检测间隔都会变小,显然是不能接受的。因为不同应用程序的需求是不一样的。

4.1 recv 返回值判断连接情况,

a. 返回0

阻塞接收的recv有时候会返回0,这仅在socket被正常关闭时才会发生。

1) 正常关闭socket closesocket;

2)关机

b.返回-1

1)  阻塞,一般对于阻塞的socket都会用setsockopt来设置socket的超时。
      当超时时间到达后,recv会返回错误,也就是-1,关闭重连接,无需心跳包

2) 掉线,断网直接关闭程序

假设使用Socket基于TCP通信协议进行C/S通信编程,客服端已经成功与服务端建立tcp连接,并且可以正常进行收发数据。

当一段时间后,服务端的程序如果调用closesocket(sClient);WSACleanup();函数关闭socket,

那么客户端的recv()将会返回0;

如果服务端没有调用closesocket(sClient);而只调用WSACleanup();或直接关闭程序,

那么客户端的recv()将会返回-1(SOCKET_ERROR)。

以上结果在局域网经过实际验证。

3)由于终端信号,服务端返回-,但是客户端依然连接,能发数据,怎么办? 心跳包重连接

其实,要判定掉线,只需要send或者recv一下,如果结果为零,则为掉线。但是,在长连接下,有可能很长一段时间都没有数据往来。理论上说,这个连接是一直保持连接的,但是实际情况中,如果中间节点出现什么故障是难以知道的。更要命的是,有的节点(防火墙)会自动把一定时间之内没有数据交互的连接给断掉。在这个时候,就需要我们的心跳包了,用于维持长连接,保活。

5.1 心跳包超时时间20~40s适宜

4.1 附录

https://www.zhihu.com/question/57736822

https://blog.csdn.net/qq_23167527/article/details/54290726

https://blog.csdn.net/liaomengge/article/details/50760831

https://www.zhihu.com/question/20849677/answer/16384522

https://www.cnblogs.com/nightwatcher/archive/2012/08/16/2643145.html

https://blog.csdn.net/tiandyoin/article/details/30044781

https://blog.csdn.net/baodi_z/article/details/43449315

http://www.nowamagic.net/academy/detail/23350382

嵌入式开发之网络心跳包---阻塞和非阻塞以及是否有必要心跳包heartbeat相关推荐

  1. Linux Socket网络编程UDP、TCP 阻塞与非阻塞 断线重连机制

    三种非阻塞模式的方法: (1) fcntl函数 int Mode = fcntl(sockfd, F_GETFL, 0);       //获取文件的Mode值     fcntl(sockfd, F ...

  2. python网络编程基础(线程与进程、并行与并发、同步与异步、阻塞与非阻塞、CPU密集型与IO密集型)...

    python网络编程基础(线程与进程.并行与并发.同步与异步.阻塞与非阻塞.CPU密集型与IO密集型) 目录 线程与进程并行与并发同步与异步阻塞与非阻塞CPU密集型与IO密集型 线程与进程 进程 前言 ...

  3. C++网络编程快速入门(三):阻塞与非阻塞式调用网络通信函数

    目录 阻塞与非阻塞定义 send与recv connect 一些问题 为什么要将监听socket设置为非阻塞 阻塞与非阻塞定义 阻塞模式指的是当前某个函数执行效果未达预期,该函数会阻塞当前的执行线程, ...

  4. 网络编程中同步与异步,IO阻塞与非阻塞总结

    IO操作分两个阶段 第1个阶段:等待数据准备好(从外部设备磁盘或网络读到内核缓冲区): 第2个阶段:采用系统调用(内核进程),操作系统内核将数据从内核缓冲区读到用户空间. 第1阶段花费的时间远远大于第 ...

  5. 阻塞与非阻塞的IO网络读写

    看我之前的文章就知道,一般对于网络读的socket,都会加上O_NONBLOCK,非阻塞的选项. int setnonblocking(int fd) {int old_option = fcntl( ...

  6. (转载)网络编程释疑之:同步,异步,阻塞,非阻塞

    一讲到网络编程的I/O模型,总会涉及到这几个概念.问了很多人,没几个能清晰地讲出他们之间的区别联系,甚至在网络上也有很多不同的观点,也不知是中国文字释义的博大精深,还是本来这几个概念就是绕人不倦.今天 ...

  7. 网络编程释疑之:同步,异步,阻塞,非阻塞

    一讲到网络编程的I/O模型,总会涉及到这几个概念.问了很多人,没几个能清晰地讲出他们之间的区别联系,甚至在网络上也有很多不同的观点,也不知是中国文字释义的博大精深,还是本来这几个概念就是绕人不倦.今天 ...

  8. linux网络编程--阻塞与非阻塞

    linux网络编程--阻塞与非阻塞 建立连接 接受连接 无阻塞的设置方式 read() write() 读操作 写操作 Linux fcntl函数详解 功能描述 函数原型 fcntl()函数五种功能 ...

  9. 【Linux网络编程学习】阻塞、非阻塞、同步、异步以及五种I/O模型

    文章目录 1. 基本概念 1.1 阻塞与非阻塞 1.2 同步与异步 1.3 为什么没有"异步阻塞" 2. 五种IO模型 2.1 阻塞 blocking 2.2 非阻塞 non-bl ...

  10. 网络IO之阻塞、非阻塞、同步、异步总结

    1.前言 在网络编程中,阻塞.非阻塞.同步.异步经常被提到.unix网络编程第一卷第六章专门讨论五种不同的IO模型,Stevens讲的非常详细,我记得去年看第一遍时候,似懂非懂,没有深入理解.网上有详 ...

最新文章

  1. git_修改git历史提交记录
  2. 修身论文2000字_那些没能写出毕业论文的博士生,究竟是败在了哪里?
  3. 程序员的“鱿鱼游戏”,你能活到第几关?
  4. A-Light-and-Fast-Face-Detector-for-Edge-Devices
  5. 1.26 Java使用自定义包
  6. 【Intellij IDEA系列】IDEA右键没有Git或svn处理方法
  7. hdu 2544 最短路 Dijkstra算法
  8. LeetCode 771. 宝石与石头(哈希)
  9. php基础:查询程序运行时间并且把科学计数法转换成正常数字
  10. 数据分析工具该如何选择
  11. eclipse使用教程(图文)
  12. Canbus通信协议
  13. 安装protobuf可能遇到的问题
  14. vb服务器获取ftp文件,vb获取ftp服务器文件时间戳
  15. strongSwan之ipsec.secrets配置手册
  16. ESP32创建局域网服务器VScode
  17. Mac M1 上 丝滑跑 Docker
  18. 达梦数据库删除用户_干货分享丨DM8用户管理
  19. 移动web-线性渐变
  20. 博图只能通过地址相同设备找到plc_西门子全系列及博图软件常见问题解答

热门文章

  1. 浅谈L0,L1,L2范数及其应用
  2. java学习笔记7--抽象类与抽象方法
  3. 关于高阶导数的一个不等式估计
  4. LWIP裸机环境下实现TCP与UDP通讯(转)
  5. Android 分享控件
  6. Alphabet Project Loon项目负责人半年再度易人
  7. Linux_《Linux命令行与shell脚本编程大全》第二章学习总结
  8. 简单的XML和JSON数据的处理
  9. 用Redis实现微博关注关系
  10. java笔记之抽象类和接口