• 【计算机网络】 TCP——四次挥手


    文章目录


    在这里插入图片描述

    流程

    1. 主动方打算关闭连接,此时会发送一个TCP首部FIN标志位被置为1的报文,也即FIN报文,之后主动方进入FIN_WAIT_1状态。
    2. 被动方收到该报文后,就向主动方发送ACK应答报文,接着被动方进入CLOSE_WAIT状态。
    3. 主动方收到被动方的ACK应答报文后,进入FIN_WAIT_2状态。
    4. 等待被动方处理完数据之后,也向主动方发送FIN报文,之后被动方进入LAST_ACK状态。
    5. 主动方收到被动方发送的FIN报文后,回一ACK应答报文,之后进入TIME_WAIT状态。
    6. 被动方收到了ACK应答报文之后,就进入了CLOSED状态,至此被动方已经完成连接的关闭。
    7. 主动方在经过2MSL一段时间之后,自动进入CLOSED状态,至此主动方也完成了连接的关闭

    考点

    • 为什么主动方发了最后一次ACK后还要等待2MSL后才能进入关闭连接?

    答:因为最后等待2MSL是为了防止最后一次ACK丢失,如果ACK丢失了,在2MSL中会再次收到FIN,那就再回一个ACK,如果没有再次收到FIN,就证明ACK没有丢失,就可以放心进入CLOSE状态了,如果不等待就关闭并且ACK包丢失了,那么被动方就会一直重复发FIN包。

    • 被动方在收到FIN后,为什么要立刻回一个ACK,等一会再发FIN?

    答:要将之前收到的数据都处理完再回复FIN包,立刻回ACK是为了防止超时重传,因为如果处理数据的时间过长就会触发超时重传机制。

  • 相关阅读:
    手撕前端面试题【javascript】
    研究mysql日志的使用
    前端将二维数组转换成树形格式数组
    程序员实现财务自由的5个方法
    Java 类和对象
    JAVA多态
    QT(37)-mosquitto-MQTT客户端
    [DRAFT] LLVM ThinLTO原理分析
    通过宏将父类protected函数在子类中提升为public
    快速排序算法 QuickSort algorithm
  • 原文地址:https://blog.csdn.net/jia_03/article/details/132818108