TCP vs UDP
共同点
tcp协议和udp协议都工作在传输层
它们的目标都是在程序之间传输数据
数据可以是文本文件、视频也可以是图片
对于tcp协议和udp协议来说,都是一堆二进制数,并没有多大的区别
区别
最大的区别在于是否基于连接
TCP协议
TCP保证上述过程的机制:
- 三次握手
- 传输确认
- 四次挥手
1. 三次握手
三次握手是建立连接的过程。当客户端向服务端发起连接时,会先发一包连接请求数据,过去询问一下,能否与你建立连接。这包数据我们称为SYN包。
如果对方同意连接,则回复一包SYN+ACK包。
客户端收到之后回复一包ACK包,连接建立。
因为这个过程中互相发送了三包数据,所以称之为三次握手。
1.1 为什么要三次握手而不是两次握手
如果服务端回复完SYN+ACK之后就建立连接存在问题,这是为了防止因为已失效的请求报文突然又传到服务器引起错误。
假设采用两次握手建立连接,客户端向服务端发送了一个SYN包来请求建立连接,因为某些未知的原因并没有到达服务器。在中间某个网络节点产生了滞留。
为了建立连接,客户端会重发SYN包,这次的数据包正常送达。
这次的数据包正常送达,服务端回复SYN+ACK之后建立起了连接。但是第一包数据阻塞的网络节点突然恢复,第一包SYN包又送达到服务端,这时服务端会误认为是客户端又发起了一个新的连接。从而在两次握手之后进入等待数据状态。
服务端认为是两个连接,而客户端认为是一个连接。造成了状态不一致。
如果在三次握手的情况下,服务端收不到最后的ACK包,自然不会认为连接建立成功。所以三次握手本质上来说,就是为了解决网络信道不可靠的问题。
1.2 需要解决的挑战
为了在不可靠的信道上建立可靠的连接,经过三次握手之后,客户端和服务端都进入了数据传输状态。我们刚才说过tcp协议需要在不可靠的信道上保证可靠的连接,现在就有几个问题需要面对。
一包数据有可能被拆成多包来进行发送。如何处理丢包问题、这些数据包到达的顺序不同(如何处理乱序问题),针对这些要求,tcp协议为每一个连接建立了一个发送缓冲区。从建立链接的第一个字节的序列号为0,后面每个字节的序列号就会增加1。发送缓冲区取一部分数据组成发送报文,在其tcp序列号中会附带序列号和长度,接收端收到数据之后需要回复确认报文。确认报文中的ACK = 序列号 + 长度,也就是下一包数据需要发送的起始序列号。
这样一问一答的发送方式可以使发送端确认发送的数据已经被对方收到。发送端也可以一次发送连续的多包数据。接收端只需要回复一次ACK就可以了。
这样发送端可以把待发送的数据分隔成一些列的碎片,发送到对端,对端根据序列号和长度,在接收后重构出来完整的数据。
假设其中丢失了某些数据包,在接收端可以要求发送端重传。
比如丢失了100-199这100个字节,接收端向发送端发送ACK = 100的报文,发送端收到后重传这一包数据,接收端进行补齐。
以上过程不区分客户端和服务端。
tcp连接是全双工的,对于两端来说,均采用上述机制。
2. 四次挥手
处于连接状态的客户端和服务端都可以发起关闭连接请求,此时需要四次挥手来进行连接关闭。
2.1 第一次挥手
假设客户端主动发起连接关闭请求,他需要将服务端发起一包FIN包,表示要关闭连接,自己进入终止等待1状态。
这是第一次挥手:
2.2 第二次挥手
服务端收到FIN包,发送一包ACK包,表示自己进入了关闭等待状态,客户端进入终止等待2状态。
这是第二次挥手:
2.3 第三次挥手
服务端此时还可以发送未发送的数据,而客户端还可以接收数据。待服务端发送完数据之后,发送一个FIN包进入最后确认状态。
这是第三次挥手:
2.4 第四次挥手
客户端进入超时等待状态。经过超时时间后关闭连接,而服务端收到ACK包后立即关闭连接。
这是第四次挥手:
2.5 为什么客户端需要等待超时时间
这是为了保证对方已收到ACK包,因为假设客户端发送完最后一包ACK包后就释放了连接。一旦ACK包在网络中丢失,服务端将一直停留在最后确认状态。
如果客户端发送完最后一包ACK包后等待一段时间,这时服务端因为没有收到ACK包会重发FIN包。客户端会响应这个FIN包,重发ACK包并刷新超时时间。
2.6 总结
这个机制和三次握手一样,也是为了保证在不可靠的网络链路中进行可靠的连接断开确认。
UDP协议
首先, UDP协议是基于非连接的。发送数据就是简单把数据包装一下。然后从网卡发出去就可以了。
数据包之间并没有状态上的联系。正因为udp这种简单的处理方式,导致它的性能损耗非常少。对于cpu,它内存资源的占用也远小于tcp。
但是对于网络传输过程中产生的丢包,udp协议并不能保证。所以udp在传输稳定性上要弱于tcp。
区别总结
1. tcp的特点
tcp传输数据稳定可靠,适用于对网络通讯质量要求较高的场景。需要准确无误的传输给对方。比如传输文件、发送邮件、浏览网页等。
2. udp的特点
udp的优点是速度快,但是可能产生丢包,所以适用于对实时性要求较高,但是对少量丢包并没有太大要求的场景。比如域名查询、语音通话、视频直播等。
udp还有一个非常重要的应用场景就是隧道网络。比如说我们常用的vpn,就是一种随道网络。以及在SDN中使用的VXLAN,也是一种隧道网络。