当前位置: 首页 > news >正文

在使用tcp长连接时,是否还需要再引入重发机制?

一 什么是tcp长连接?

       在TCP(Transmission Control Protocol)中,长连接是指在通信过程中保持连接状态的一种方式,相对于短连接而言。长连接通常用于需要频繁通信的场景,以减少连接建立和断开的开销。在长连接中,数据可以在多次交互中传输,而连接保持打开状态。

二 有没有为tcp长连接引入重发机制必要性?

      关于是否需要设置重发机制,TCP本身已经包含了一套可靠的数据传输机制,包括重传机制。TCP使用序号和确认来保证数据的可靠传输。如果发现数据包未被正确接收,TCP将触发重传机制,将丢失的数据重新发送。这个机制确保了数据的可靠性,而不需要应用层额外的重发机制

        

三  若需要引入重发机制,只能在客户端引入重发机制(不要在服务端引入)

       如果要为tcp长连接引入重发机制,那么只能在客户端可引入重发机制才是合理的,服务器的端口和IP都是固定的,如果是一些物联网设备可能有大量设备客户端在连接,此时服务端只需保持稳定处理协议通讯数据。每个物联网设备ip和端口都会随着每次的连接而变化,当一个物联网设备因通讯或其它问题断开时,服务器此时是不能再主动连接客户端的物联网设备,而客户端物联网设备可以重新连接到指定IP和端口的服务器。(此时服务端才有客户端的新ip和端口)只有在客户端连通的情况下,服务端才可以发送数据,这就说明复发机制只合适在客户端。

       

四  极端环境下的服务端重试设计(不要这样做)

  1. 应用层重发: 在应用层实现一个重发机制。当服务端检测到数据发送失败(例如,未收到客户端的确认或收到了明显的错误响应),它可以记录未成功发送的数据,并在稍后的时间点尝试重新发送这些数据。

  2. 定时重发: 在服务端引入一个定时器,定期检查之前未成功发送的数据,并进行重发。这可以通过定时任务、定时器或其他机制来实现。定时重发的时间间隔可以根据具体需求进行调整。

  3. 指数退避: 在实施重发时,可以考虑使用指数退避(exponential backoff)策略,即在每次重发之后将重发时间间隔逐渐增加,以避免在网络或服务端出现瞬时问题时引发过多的重发。

  4. 重发次数限制: 为了防止无限重发,可以在服务端设置一个重发次数的上限。如果达到了这个上限仍未成功,则可能需要采取其他处理方式,例如记录日志、通知管理员或者考虑其他错误处理策略。

五 总结

     tcp长连接本身是相当稳定,并且本身也自带重试机制。别在画蛇添足为tcp长连接协议服务端再设计重发机制。

        

http://www.lryc.cn/news/271584.html

相关文章:

  • 记一次Oracle Cloud计算实例ssh恢复过程
  • 2024年01月数据库流行度最新排名
  • Stable Diffusion API入门:简明教程
  • 数据结构--二叉搜索树的实现
  • 《微信小程序开发从入门到实战》学习六十八
  • 阿里是如何去“O”的?
  • 蓝桥杯备赛 day 1 —— 递归 、递归、枚举算法(C/C++,零基础,配图)
  • 87 双指针解验证回文字符串II
  • 【排序算法】【二叉树】【滑动窗口】LeetCode220: 存在重复元素 III
  • OS 7--DNS配置+Apache发布网站
  • 1月2日代码随想录二叉树的最小深度及层序遍历总结
  • RK3568平台开发系列讲解(Linux系统篇)PWM系统编程
  • Linux CPU 数据 Metrics 指标解读
  • Ansible自动化运维(一)简介及部署、清单
  • 深度学习MLP_实战演练使用感知机用于感情识别_keras
  • [ffmpeg系列 02] 音视频基本知识
  • 【ASP.NET Core 基础知识】--目录
  • java数据结构与算法刷题-----LeetCode509. 斐波那契数
  • vue3 element plus el-table封装(二)
  • cnn lstm结合网络
  • Ubuntu连接xshell
  • nginx安装和配置
  • 【头歌实训】kafka-入门篇
  • 华为云创新中心,引领浙南的数字化腾飞
  • 240101-5步MacOS自带软件无损快速导出iPhone照片
  • github鉴权失败
  • 2023湾区产城创新大会:培育数字化供应链金融新时代
  • 多维时序 | MATLAB实现SSA-GRU麻雀算法优化门控循环单元多变量时间序列预测
  • 二叉树的前序遍历 、二叉树的最大深度、平衡二叉树、二叉树遍历(leetcode)
  • SQL之CASE WHEN用法详解