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,这样才能保证服务端的数据完全发送到了客户端手中。

  • 相关阅读:
    Django 同步数据库的时候app中的models的表没有成功创建
    mysql 个人博客应用的建表和相关查询
    lambda(),map(),filter()
    用小白鼠找毒药
    python 汉诺塔问题
    灰色预测
    python可视化图标
    exel数据可视化
    543. 二叉树的直径
    236. 二叉树的最近公共祖先
  • 原文地址:https://www.cnblogs.com/OFSHK/p/14580166.html
Copyright © 2011-2022 走看看