三次握手
TCP建立连接 TCP 是面向连接的协议,所以使用 TCP 前必须先建立连接,而建立连接是通过三次握手而进行的。
面试回答: TCP/IP协议是传输层一个面向的连接的安全的协议,三次握手的协议是为了保证能够建立一个安全的传输环境。
第一次握手,是由客户端发起的,客户端会向服务端发送一个报文,在报文中,SYN位标志位置1,同时生成一个随机的32 位序列号seq,当服务端收到这个请求后,就知道,客户端想跟我建立一个连接,于是服务端就会向客户端回复一个确认消息报文,报文中SYN位标志位置1,同时生成一个新的序列号seq,不仅如此,确认标志位ACK置1,确认序号ack=客户端的序列号seq+1。
此时两次握手过后,其实客户端已经知道了,我既能给服务端发送消息,还能够接收到服务端发送给我的消息,但服务端只是接收到了客户端的消息,但不能确认,自己的消息能不能被客户端接收到,故还需要第三次握手。
第三次握手,是客户端向服务端的一个确认消息报文,告诉服务端,我已经接收到了消息,同时SYN标志位置1,确认序号ack=服务器序列号+1.
至此,三次握手就已经建立完毕了,客户端与服务端就可以正式进行数据传输了。
?
三个方面分析三次握手的原因
- 三次握手才可以阻止历史重复连接的初始化(主要原因)
三次握手的首要原因是为了防止旧的重复连接初始化造成混乱
两次握手只保证了一方的初始序列号能被对方成功接收,没办法保证双方的初始序列号都能被确认接收
不使用[两次握手]和[四次握手]的原因:
- 「两次握手」:无法防止历史连接的建立,会造成双方资源的浪费,也无法可靠的同步双方序列号;
- 「四次握手」:三次握手就已经理论上最少可靠连接建立,所以不需要使用更多的通信次数。
总结: TCP 建立连接时,通过三次握手能防止历史连接的建立,能减少双方不必要的资源开销,能帮助双方同步初始化序列号。序列号能够保证数据包不重复、不丢弃和按序传输。
|