美文网首页
TCP的三次握手和四次挥手,为什么不是两次握手?为什么挥手多一次

TCP的三次握手和四次挥手,为什么不是两次握手?为什么挥手多一次

作者: 陈萍儿Candy | 来源:发表于2020-11-26 14:45 被阅读0次

    客户端简称A,服务器端简称B

    1)TCP建立连接需要三次握手

    A向B表示想跟B进行连接(A发送syn包,A进入SYN_SENT状态)
    B收到消息,表示我也准备好和你连接了(B收到syn包,需要确认syn包,并且自己也发送一个syn包,即发送了syn+ack包,B进入SYN_RECV状态)
    A收到消息,并告诉B表示我收到你也准备连接的信号了(A收到syn+ack包,向服务器发送确认包ack,AB进入established状态)开始连接。

    2)TCP断开连接需要四次挥手

    A向B表示想跟B断开连接(A发送fin,进入FIN_WAIT_1状态)
    B收到消息,但是B消息没发送完,只能告诉A我收到你的断开连接消息(B收到fin,发送ack,进入CLOSE_WAIT状态)
    过一会,B数据发送完毕,告诉A,我可以跟你断开了(B发送fin,进入LAST_ACK状态)
    A收到消息,告诉B,可以他断开(A收到fin,发送ack,B进入closed状态)

    3)为什么挥手多一次 其实正常的断开和连接都是需要四次:

    A发消息给B
    B反馈给A表示正确收到消息
    B发送消息给A
    A反馈给B表示正确收到消息。

    但是连接中,第二步和第三步是可以合并的,因为连接之前A和B是无联系的,所以没有其他情况需要处理。而断开的话,因为之前两端是正常连接状态,所以第二步的时候不能保证B之前的消息已经发送完毕,所以不能马上告诉A要断开的消息。这就是连接为什么可以少一步的原因。

    4)为什么连接需要三次,而不是两次。正常来说,我给你发消息,你告诉我能收到,不就代表我们之前通信是正常的吗?

    简单回答就是,TCP是双向通信协议,如果两次握手,不能保证B发给A的消息正确到达。

    TCP 协议为了实现可靠传输, 通信双方需要判断自己已经发送的数据包是否都被接收方收到, 如果没收到, 就需要重发。

    TCP是怎么保证可靠传输的?

    序列号和确认号。比如连接的一方发送一段80byte数据,会带上一个序列号,比如101。接收方收到数据,回复确认号181(180+1),这样下一次发送消息就会从181开始发送了。

    所以握手过程中,比如A发送syn信号给B,初始序列号为120,那么B收到消息,回复ack消息,序列号为120+1。同时B发送syn信号给A,初始序列号为256,如果收不到A的回复消息,就会重发,否则丢失这个序列号,就无法正常完成后面的通信了。

    这就是三次握手的原因。

    相关文章

      网友评论

          本文标题:TCP的三次握手和四次挥手,为什么不是两次握手?为什么挥手多一次

          本文链接:https://www.haomeiwen.com/subject/fmuaiktx.html