一、什么是 TCP 粘包/拆包?发生的原因?怎么解决?
TCP粘包:指在进行TCP数据传输时,多个小的数据包被合并成一个大的数据包进行传输的现象。
TCP拆包:指一个大的数据包被拆分成多个小的数据包进行传输的现象。
原因:
1、应用程序向 TCP 套接字写入数据时,没有明确的边界划分,TCP 协议会根据自己的优化策略将数据进行合并或拆分。
2、数据包大小超过了网络传输的最大传输单元(MTU)
3、如果接收方读取数据的速度较慢,而发送方发送数据的速度较快,那么就可能会导致多个数据包在接收方的缓冲区中堆积,从而形成粘包现象。
解决方案:
1、消息定长。
2、在包尾部增加回车符或者换行符等特殊字符进行分割
3、自定义数据结构:分为消息头和数据,消息头中有字段说明紧随其后的数据有多大。
4、使用其他复杂的协议或框架。
二、为什么域名解析用 UDP 协议?
1、报文开销小:UDP 是一种无连接的传输层协议,其报文头部相对简单,只有 8 个字节,相比之下,TCP 的报文头部至少为 20 个字节。在进行域名解析时,通常查询请求和响应的数据量都比较小,UDP 的小报文头部可以减少网络传输的开销。
2、快速传输:UDP 不需要建立链接,直接将数据封装成报文发送出去,因此可以快速地进行数据传输,对于域名解析这种对响应时间要求较高的应用来说,UDP 的快速传输性非常重要。
三、为什么区域传送用 TCP 协议?
1、数据完整性和可靠性要求高:区域传送涉及传输整个区域的域名数据,数据量通常较大。
TCP 协议提供了可靠的数据传输机制,能够确保数据的完整性,保证所有的数据都能准确无误地从源服务器传输到目标服务器,如果使用了不可靠的协议,就可能会出现数据丢失或损坏地情况,导致域名解析出现错误。
2、连接的稳定性和有序性:区域传送通常是在 DNS 服务器之间进行的重要操作,需要一个稳定的连接来保证数据的持续传输。TCP 协议通过建立连接、维护连接状态等机制,提供了稳定的通信通道。在区域传送中域名数据的顺序是有意义的,如果数据乱序到达,可能会导致解析错误。yiyi