TCP和UDP的区别 常用协议

TCP与UDP是两种主要的传输层协议,TCP提供面向连接的、可靠的字节流服务,适用于文件传输等需要确保数据准确无损的场景;而UDP则是无连接的、不可靠的,适合实时通信如视频会议。WebSocket是一种在浏览器和服务器间建立持久连接的协议,允许双向通信。TCP的三次握手确保连接可靠性,四次挥手则确保连接完全关闭。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

TCP和UDP的区别

UDPTCP
是否连接无连接面向连接
是否可靠不可靠传输,不使用流量控制和拥塞控制可靠传输(数据顺序和正确性),使用流量控制和拥塞控制
连接对象个数支持一对一,一对多,多对一和多对多交互通信只能是一对一通信
传输方式面向报文面向字节流
首部开销首部开销小,仅8字节首部最小20字节,最大60字节
适用场景适用于实时应用,例如视频会议、直播适用于要求可靠传输的应用,例如文件传输

TCP的可靠传输机制

TCP 的可靠传输机制是基于连续 ARQ 协议和滑动窗口协议的。

TCP 就是通过控制发送窗口的长度来控制报文 段的发送速率。

但是 TCP 协议并不完全和滑动窗口协议相同,因为许多的 TCP 实现会将失序的报文段给缓存起来,并且发生重传时,只会重 传一个报文段,因此 TCP 协议的可靠传输机制更像是窗口滑动协议和选择重传协议的一个混合体。

那为什么要三次握手呢?两次不行吗?

        TCP 三次握手的建立连接的过程就是相互确认初始序号的过程,告诉对方,什么样序号的报文段能够被正确接收。

        为了确认双方的接收能力和发送能力都正常,第三次握手的作用是客户端对服务器端的初始序号的确认。如果只使用两次握手,那么服务器就没有办法知道自己的序号是否 已被确认。同时这样也是为了防止失效的请求报文段被服务器接收,而出现错误的情况。


对 WebSocket 的理解

WebSocket是HTML5提供的一种浏览器与服务器进行全双工通讯的网络技术,属于应用层协议。它基于TCP传输协议,并复用HTTP的握手通道。浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接, 并进行双向数据传输。

WebSocket 的出现就解决了半双工通信的弊端。它最大的特点是:服务器可以向客户端主动推动消息,客户端也可以主动向服务器推送消息。

那为什么要三次握手呢?两次不行吗?

        TCP 三次握手的建立连接的过程就是相互确认初始序号的过程,告诉对方,什么样序号的报文段能够被正确接收。

        为了确认双方的接收能力和发送能力都正常,第三次握手的作用是客户端对服务器端的初始序号的确认。如果只使用两次握手,那么服务器就没有办法知道自己的序号是否 已被确认。同时这样也是为了防止失效的请求报文段被服务器接收,而出现错误的情况。

三次握手:

  • 第一次握手: 客户端向服务端发送连接请求报文段。该报文段中包含自身的数据通讯初始序号。请求发送后,客户端便进入 SYN-SENT 状态。
  • 第二次握手: 服务端收到连接请求报文段后,如果同意连接,则会发送一个应答,该应答中也会包含自身的数据通讯初始序号,发送完成后便进入 SYN-RECEIVED 状态。
  • 第三次握手: 当客户端收到连接同意的应答后,还要向服务端发送一个确认报文。客户端发完这个报文段后便进入 ESTABLISHED 状态,服务端收到这个应答后也进入 ESTABLISHED 状态,此时连接建立成功。

TCP 三次握手的建立连接的过程就是相互确认初始序号的过程,告诉对方,什么样序号的报文段能够被正确接收。 第三次握手的作用是客户端对服务器端的初始序号的确认。如果只使用两次握手,那么服务器就没有办法知道自己的序号是否 已被确认。同时这样也是为了防止失效的请求报文段被服务器接收,而出现错误的情况。

四次挥手:

  • 第一次挥手: 若客户端认为数据发送完成,则它需要向服务端发送连接释放请求。
  • 第二次挥手:服务端收到连接释放请求后,会告诉应用层要释放 TCP 链接。然后会发送 ACK 包,并进入 CLOSE_WAIT 状态,此时表明客户端到服务端的连接已经释放,不再接收客户端发的数据了。但是因为 TCP 连接是双向的,所以服务端仍旧可以发送数据给客户端。
  • 第三次挥手:服务端如果此时还有没发完的数据会继续发送,完毕后会向客户端发送连接释放请求,然后服务端便进入 LAST-ACK 状态。
  • 第四次挥手: 客户端收到释放请求后,向服务端发送确认应答,此时客户端进入 TIME-WAIT 状态。该状态会持续 2MSL(最大段生存期,指报文段在网络中生存的时间,超时会被抛弃) 时间,若该时间段内没有服务端的重发请求的话,就进入 CLOSED 状态。当服务端收到确认应答后,也便进入 CLOSED 状态。

TCP 使用四次挥手的原因是因为 TCP 的连接是全双工的,所以需要双方分别释放到对方的连接,单独一方的连接释放,只代 表不能再向对方发送数据,连接处于的是半释放的状态。

最后一次挥手中,客户端会等待一段时间再关闭的原因,是为了防止发送给服务器的确认报文段丢失或者出错,从而导致服务器 端不能正常关闭。

### TCP协议UDP协议的主要区别 TCP(Transmission Control Protocol,传输控制协议UDP(User Datagram Protocol,用户数据报协议)是两种常用的传输层协议,它们各自具有不同的特性、功能以及适用场景。 #### 1. 连接模式 TCP是一种面向连接的协议,在正式收发数据前必须先建立可靠的连接,这一过程通过三次握手完成[^1]。而UDP则属于无连接的协议,无需事先建立连接即可直接发送数据包[^3]。 #### 2. 可靠性 TCP提供了高可靠性的数据传输服务,它能够确保数据按序到达目标设备,并且具备重传丢失数据的功能[^4]。相比之下,UDP并不保证数据包的顺序性完整性,可能会发生丢包或乱序现象[^2]。 #### 3. 性能表现 由于TCP需要维护连接状态并执行复杂的错误检测机制,其性能相对较低;然而这些额外操作正是为了保障数据传输的质量所必需的。相反地,UDP因为省去了许多控制环节,所以在速度方面占据优势,尤其适合那些可以容忍一定范围内的数据损失的应用场合[^3]。 #### 4. 首部开销 从头部结构来看,TCP头部较为复杂,包含了源端口号、目的端口号等多个字段用于实现各种高级功能;而UDP头部比较简单轻量级,仅需四个固定长度字段就能满足基本需求。 ### 适用场景分析 - **Web浏览**: 当用户利用浏览器访问互联网站点时,HTTP/HTTPS这类高层应用依赖于底层稳定的TCP通道来传递请求响应消息流,从而确保存取页面内容时不被中断或者损坏[^2]。 - **邮件系统**: SMTP(Simple Mail Transfer Protocol), IMAP(Internet Message Access Protocol) POP(Post Office Protocol) 等电子邮件相关标准均采用TCP作为基础载体,以保护信件资料免受中途遗失风险影响[^2]。 - **视频会议&在线游戏**: 对于此种强调即时互动效果的服务形式而言,即使偶尔存在轻微的画面跳帧亦可接受,因此选用快速高效的UDP更为合适。 - **DNS查询**: 域名解析服务经常运用短小精悍的UDP分组来进行高效快捷的操作处理[^3]。 ```python import socket def create_tcp_socket(): tcp_sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) return tcp_sock def create_udp_socket(): udp_sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) return udp_sock ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值