zoukankan      html  css  js  c++  java
  • 计算机网络

    为什么不是两次握手?

    因为TCP是全双工通信,需要保证服务端和客服端都能发送和接收数据。两次握手无法保证服务端和客户端的接发功能都是ok的。

    为什么不是四次握手?

    四次握手会降低连接的速度和效率,因为三次足够确保双方的接发功能是否完好。

    为什么不是三次挥手?

    中间的两个部分为什么不能合成一个步骤/一起发送?

    简单来说,就是因为客户端在第1次挥手的时候,服务端可能还在发送数据,所以第2次挥手和第3次挥手不能合并。ACK(表示响应)和FIN(表示关闭链接)的分开发送导致挥手比握手多了一次。

    详细过程和解释见下:

    四次挥手(具体带标志位)过程:
    
    1. 客户端执行主动关闭,发送FIN的包,表示客户端的数据发送完毕。
    
    2. 服务端这个时候是被动关闭的,发送确认ACK包。
    
    3. 服务端给客户端发送FIN,告诉客户端我也关闭。
    
    4. 客户端确认服务端的ACK包。
    

    首先我们要知道,TCP是全双工通信,TCP在断开连接时,需要服务端和客服端都确定对方将不再发送数据才行。在这四次挥手过程中我们可以看到,第一次挥手客户端发送FIN包,表示已发送数据完毕,但这时服务端可能还有数据没有发送完,所以处于一个被动关闭的状态,所以需要先发送给客户端一个ACK包去进行相应,然后再等待自己的数据发送完成后才能向客户端发送一个FIN包,来表示自己的数据也已发送完成。所以中间这两个过程是无法合并成一个的,中间必须分两次来发送ACK和FIN,这样才能保证服务端的数据完全发送到了客户端手中。

  • 相关阅读:
    vue路由的两种模式,hash与history
    javascript的继承小结
    attr和prop区别
    ie6、7下 text-indent 问题
    推荐链接
    iphone中 input圆角bug
    gif图片加载问题
    IE7中绝对定位元素之间的遮盖问题
    多行文本溢出显示省略号(...)的方法
    ie6兼容之绝对定位元素内容为空时高度问题
  • 原文地址:https://www.cnblogs.com/OFSHK/p/14580166.html
Copyright © 2011-2022 走看看