zoukankan      html  css  js  c++  java
  • TCP四次挥手

    TCP四次挥手

    • enter image description here
    • 假设Client端发起中断连接请求,也就是发送FIN报文。Server端接到FIN报文后,意思是说"我Client端没有数据要发给你了",可是假设你还有数据没有发送完毕,则不必急着关闭Socket,能够继续发送数据。所以你先发送ACK,"告诉Client端,你的请求我收到了,可是我还没准备好,请继续你等我的消息"。这个时候Client端就进入FIN_WAIT状态,继续等待Server端的FIN报文。当Server端确定数据已发送完毕,则向Client端发送FIN报文,"告诉Client端,好了,我这边数据发完了,准备好关闭连接了"。Client端收到FIN报文后,"就知道能够关闭连接了,可是他还是不相信网络,怕Server端不知道要关闭,所以发送ACK后进入TIME_WAIT状态,假设Server端没有收到ACK则能够重传。“,Server端收到ACK后,"就知道能够断开连接了"。Client端等待了2MSL后依旧没有收到回复,则证明Server端已正常关闭,那好,我Client端也能够关闭连接了。Ok,TCP连接就这样关闭了!
    • 为什么TIME_WAIT状态须要经过2MSL(最大报文段生存时间)才干返回到CLOSE状态?
      • 尽管按道理,四个报文都发送完成,我们能够直接进入CLOSE状态了,可是我们必须假象网络是不可靠的,又能够最后一个ACK丢失。所以TIME_WAIT状态就是用来重发可能丢失的ACK报文。
  • 相关阅读:
    简单分页案例
    layer弹出层
    layDate 日期与时间组件 入门
    error: Microsoft Visual C++ 14.0 is required. Get it with "Microsoft Visual C++ Build Tools":解决方案
    eclipse常用快捷键
    javascript DOM编程艺术(第2版)
    webstorm破解
    Intellij IDEA搭建vue-cli项目
    颜色rgba、hsla
    文本阴影、换行、溢出
  • 原文地址:https://www.cnblogs.com/frankltf/p/10314811.html
Copyright © 2011-2022 走看看