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

【计算机网络】TCP心跳机制、TCP粘包问题

创作不易,本篇文章如果帮助到了你,还请点赞 关注支持一下♡>𖥦<)!!
主页专栏有更多知识,如有疑问欢迎大家指正讨论,共同进步!
更多计算机网络知识专栏:计算机网络🔥
给大家跳段街舞感谢支持!ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ

在这里插入图片描述


目录

  • 一、心跳机制
  • 二、粘包问题

一、心跳机制

在长连接下,可能有很长一段时间没有数据往来,为了保持长连接存活,存在心跳机制

每隔几分钟就发送一个固定信息给服务端,服务端收到后也回复一个固定信息,以表示连接仍然有效

同时 心跳机制还可以用于检测连接是否断开或出现故障

但是 心跳机制会增加网络流量

在这里插入图片描述

二、粘包问题

由于TCP是基于字节流传输,没有边界,可以合并,合并拆不开就是粘包

(UDP没有这个问题,因为UDP每个消息都有明确的边界)

解决办法:

  • 1.设置标志位(开始/结束)
    在数据包中的开始和结束位置添加标志位,对端收到数据根据标志位进行拆包
    标志位可能与数据内容冲突,导致拆包失败

  • 2.固定包大小
    将每个数据包的大小固定,接收端根据固定大小来接收数据,从而避免粘包问题
    可能会造成数据浪费

  • 3.先发数据长度,再发数据包
    在发送数据前,先发送数据长度,接收端和发送端都要在协议中定义好数据长度
    额外发送数据长度会增加网络流量

  • 4.短连接
    每次只发送一个完整的数据包,然后关闭连接
    增加连接建立和关闭的开销

粘包问题发生在传输层和应用层之间


在这里插入图片描述

大家的点赞、收藏、关注将是我更新的最大动力! 欢迎留言或私信建议或问题。
大家的支持和反馈对我来说意义重大,我会继续不断努力提供有价值的内容!如果本文哪里有错误的地方还请大家多多指出(●'◡'●)
http://www.lryc.cn/news/265752.html

相关文章:

  • 【Linux驱动】字符设备驱动程序框架 | LED驱动
  • 关于编程网站变成了地方这件事
  • stable diffusion工作原理
  • 华清远见嵌入式学习——ARM——作业2
  • R语言中使用ggplot2绘制散点图箱线图,附加显著性检验
  • 51单片机的羽毛球计分器系统【含proteus仿真+程序+报告+原理图】
  • 设计模式之-责任链模式,快速掌握责任链模式,通俗易懂的讲解责任链模式以及它的使用场景
  • Qt通用属性工具:随心定义,随时可见(一)
  • Python中json模块的使用与pyecharts绘图的基本介绍
  • nodejs+vue+微信小程序+python+PHP医院挂号系统-计算机毕业设计推荐
  • 数据大模型与低代码开发:赋能技术创新的黄金组合
  • Redis BitMap(位图)
  • 使用eclipse创建一个java文件并运行
  • C#上位机与欧姆龙PLC的通信05---- HostLink协议
  • Uniapp 开发 BLE
  • c语言排序算法
  • 【机器学习】模式识别
  • 【Prometheus|报错】Out of bounds
  • 【音视频】Mesh、Mcu、SFU三种框架的总结
  • 高级算法设计与分析(四) -- 贪心算法
  • MATLAB - 机器人逆运动学设计器(Inverse Kinematics Designer APP)
  • 使用OpenCV DNN模块进行人脸检测
  • C#中使用OpenCV的常用函数
  • 使用Swift Package Manager (SPM)实现xcframework分发
  • 非阻塞 IO(NIO)
  • Android应用-flutter使用Positioned将控件定位到底部中间
  • Django 简单图书管理系统
  • C++内存管理和模板初阶
  • QtRO(Qt Remote Objects)分布式对象远程通信
  • 【K8s】1# 使用kuboard-spray安装K8s集群