TCP 与 UDP

0. tcp 与 udp 的 异同特性

|---------------|----------------------------------------------------------------------------|---------------------------------------------------------|
| | TCP | UDP |
| name | 传输控制协议 | 用户数据报协议 |
| 面向连接? | 需要 * 传输数据前建立连接 * 传输完毕后断开连接 | 不需要 |
| 可靠的传输数据? | 可靠 有确认机制(三次握手) * 有确认、窗口、重传、拥塞控制的机制 保证数据可靠传输 * 保证数据无差错、不丢失、不重复、有序到达 | 不可靠 没有确认机制 * 收到报文后,没有确认收到信息返回 可能会造成问题: * 数据丢失 * 数据非顺序到达 |
| 传输的消息有状态? | 有状态 需要维持复杂的连接状态表 * 记录消息是否被发送 * 记录消息是否被接受 | 无状态 |
| 数据传输的形式? | 面向连续的字节流 | 面向独立的报文 |
| 协议首部开销? | 20~60 字节 | 8 字节 |
| 服务形式or范围 | 仅支持 点对点通信 | 支持 一对一、 一对多、 多对一、多对多通信 |
| 如何选择? | 一般用于传输准确性要求高场景 * 文件传输 * 发送和接受邮件 * 远程登录 | 一般用于即时通信 * 语音 * 视频 * 比如看视频少了一两帧区别不大 * 直播 |
| 传输效率 | 由于TCP 在传输 的时候 ,多了连接、确认、重传等机制 相比TCP传输速率低许多 ||

1. Tcp

1.1 建立与断开连接

(1)tcp三次握手 ------ 建立连接

(2)Tcp四次挥手------断开连接

1.2 传输的可靠性保证

tcp是一种面向连接的、可靠的、基于字节流的传输协议,通过一系列机制来保证数据的可靠传输,主要包括:

1. 超时重传

  • 通过在每个数据包上标记一个序列号,并等待接收方的确认应答
    • 如果一定时间内未收到应答,在设定的超时时间过后,再次发送

2. 流量控制

  • 防止接受过多的数据,导致接收方无法处理
    • 连接的双方都有固定大小的缓冲空间
    • 接受方通过tcp窗口来告知发送方 还有多少缓存空间
    • 使用到了流量控制协议,即 tcp通过滑动窗口来实现
      • 提示发送方控制发送的数据量

3. 拥塞控制

  • 防止发送过多的数据,导致网络拥塞
    • 通过检测网络的拥塞状态(拥塞控制算法)来动态调整发送频率

4. 校验和

  • 如果收到首部和数据的校验和 有差错,则丢弃此报文
    • 端对端的校验和 可以检测到数据在传输过程中的变化
相关推荐
VVVVWeiYee2 小时前
项目2路由交换
运维·服务器·网络·网络协议·信息与通信
芷栀夏4 小时前
如何在任何地方随时使用本地Jupyter Notebook无需公网IP
服务器·ide·tcp/ip·jupyter·ip
xserver26 小时前
ensp 基于EASY IP的公司出口链路配置
网络·tcp/ip·智能路由器
手心里的白日梦7 小时前
UDP传输层通信协议详解
网络·网络协议·udp
红米饭配南瓜汤7 小时前
WebRTC服务质量(11)- Pacer机制(03) IntervalBudget
网络·网络协议·音视频·webrtc·媒体
唔知小罗9 小时前
网络编程UDP—socket实现(C++)
网络·c++·udp
萧瑟其中~10 小时前
计算机网络:TCP/IP网络协议
网络协议·tcp/ip·计算机网络
IT 古月方源10 小时前
ensp 关于ARRP 的讲解 配置
运维·开发语言·网络·tcp/ip·智能路由器
林枫依依11 小时前
如何让Tplink路由器自身的IP网段 与交换机和电脑的IP网段 保持一致?
网络·tcp/ip·智能路由器
极客小张11 小时前
基于STM32的智慧农业控制系统设计:python可视化、UART、I2C、TCP/HTTP技术
python·stm32·单片机·物联网·tcp/ip·毕业设计·课程设计