TCP网络协议

TCP粘包

  1. TCP在接收数据时,多包数据粘在了一起

  2. 原因:

  3. TCP发送数据时,没有及时发走,会根据缓冲区数据的情况进行重新组包;

  4. TCP接收方,没有及时读走缓冲区数据,导致缓冲区大量数据缓存。

  5. 如何解决TCP粘包:

  6. 发指定大小字节(结构体)

struct data

{

int id;

float tmp;

xxx;

};

指定在相同平台上使用,注意结构体对其齐问题。

  1. 发送具有指定分隔符的数据

"hello world\n"

"how are you\n"

  1. 封装自定义数据帧

AA 0d 01 00 00 00 14 00 00 00 15 xx xx xx xx sum BB

网络抓包

网络抓包:抓取通过设备网卡的数据

wireshark:网络抓包工具:

  1. 分析和追踪网络问题

  2. 查看网络协议栈

安装:sudo apt-get install wireshark

  1. sudo wireshark

  2. 选择通信设备的网卡---》any

  3. 选择抓取的过滤条件

  4. 开始抓取

  5. 进行一次通信

TCP报文头

标志位:

  1. URG: 紧急指针标志, 为1时表示紧急指针有效, 该报文应该优先传送。

  2. ACK: 确认应答标志

  3. PSH: 表示发送数据,提示接收端从TCP接收缓冲区中读走数据,为接收后续数据腾出空间

  4. RST: 重置连接标志

  5. SYN: 表示请求建立一个连接

  6. FIN: finish标志, 表示释放连接

TCP机制

  1. 应答机制:为每个数据增加序列发,发送数据时,第一个数据的序号作为报文中的序号。

接收方收到相关数据,会回应ACK报文,报文中的确认号是接收方下次希望接收到的数据的

起始序号。

  1. 超时重传机制:TCP发送数据后会在一定的时间内等待ACK,假设在指定时间ACK未收到,则视这包数据已经

丢失,会重新传输这包数据。

  1. 流量控制机制:根据接收方接收数据的能力,调整窗口大小,通知发送发进行流量控制
相关推荐
念恒123064 分钟前
ROS2入门
linux·运维·服务器
.select.14 分钟前
TCP 8 (拥塞控制)
服务器·网络·tcp/ip
小糖学代码20 分钟前
LLM系列:1.python入门:6.元组型对象(tuple)
linux·运维·服务器·python
晴天¥29 分钟前
使用Openfiler为达梦数据库集群搭建共享存储
运维·服务器·存储
Saniffer_SH32 分钟前
【市场洞察】一叶知秋 - 从2026年开年Quarch公司PCIe 6.0测试工具销售状况说起
服务器·人工智能·嵌入式硬件·测试工具·fpga开发·自动化·压力测试
2603_954708311 小时前
多微电网系统架构:集群协同与能量互济的网络设计
网络·人工智能·分布式·物联网·架构·系统架构
Three~stone1 小时前
Cisco Packet Tracer 5.3 安装教程以及汉化教程
网络
llilian_161 小时前
铷原子频率标准 以时频基准破局,为计量校准赋能 时基铷钟
网络·功能测试·单片机·嵌入式硬件·测试工具·算法
大黄说说1 小时前
Go并发双雄:WaitGroup与Channel的抉择与协作
java·服务器·数据库
同聘云2 小时前
阿里云国际站服务器高防是什么意思?如何选择高防服务器?
运维·服务器·网络