三次握手

三次握手具体过程是什么?

  1. 客户端发送一个数据包

    • 将SYN置成1,表示希望建立连接

    • 这个包中的序列号是X

  2. 服务器收到客户端发来的数据包

    • 通过SYN得知这是一个建立连接的请求

    • 于是发送一个响应包

    • 并将SYN和ACK标志成1,

    • 假设发送包的序列号是是y

    • 确认序列号必须是x+1,表示收到了客户端发来的SYN请求

  3. 客户端收到服务端的响应包后需要进行确认

    • 确认包中将ACK置为1,并将确认序列号设置为y+1。表示收到了服务端的SYN请求

为什么需要第三次握手?

主要是要两个目的:信息对等防止超时

信息对等

防止超时

即防止出现请求超时,导致脏连接。假设发生了下面的情况:

  • 客户端发送第一个请求,但是请求超时,报文依旧在网络上传输
  • 客户端发送了第二个请求,服务端成功接收到了
  • 服务端发送确认报文,连接成功
  • 传输数据完后,释放连接(两者就都不是SYN_CENT状态)
  • 之后,超时请求到达服务端,然后服务端接收,建立脏连接
  • 因为客户端不是SYN_CENT状态,直接丢弃服务端的确认报文,导致只有服务端单方面建立连接

如果是三次握手的情况,服务端即使收到了超时请求报文,但是如果客户端迟迟不发送确认报文,导致连接超时,不会带来脏数据

四次挥手

四次挥手具体过程是什么?

  1. 客户端想要关闭连接,传递FIN信号给服务端

    • 客户端进入wait1状态
  2. 服务端应答了客户端,发送了ACK
    • 告诉客户端可以断开,但是你要等我处理完数据
    • 服务端进入close_wait状态
    • 客户端发送服务端的确认报文后会进入wait2状态
  3. 服务端处理完数据,发送FIN信号
    • 服务端进入了last_ack状态
  4. 客户端给服务端发送确认报文
    • 客户端进入time_wait状态
    • 服务端进入close状态
  5. 客户端经过2倍的MSL时间后,进入close状态

为什么需要四次挥手?

其实,我们可以把三次握手先看成次四次握手。

因为在握手中,我们可以将确认报文和SYN信号一起发送过去,合二为一。

但是挥手却不可以,因为这个过程客户端发送FIN信号后,虽然不可以发送数据,但是还可以接收服务端的数据。所以,不能合并

为什么要等到2倍的MSL时间而不是直接关闭?

MSL表示报文最大的生存时间,即任何报文在网络上存在的最长时间,超过这个时间就会被丢弃

确保服务端成功接收到ACK报文

假设碰到最坏的情况,服务端没有接收到ACK报文,服务端就需要重新发送SYN(一个MSL),服务端接收ACK(一个MSL)

因此客户端为了确保对方能够收到ACK报文,所以必须要等待两被的MSL,然后关闭。

确保新连接不接受过期数据包

假设网络中有一个迟到的数据包,没有被服务端接收

断开连接后,客户端又在相同的端口与服务器进行了一个新的连接

那这个时候,迟到的数据包达到了服务端,服务端以为是新的客户端发送过来的消息。

那么通过,经过2倍的MSL足足可以让两个方向上的数据包都被丢弃

之后,建立的新连接就不过接收过期的数据包了

如果对你我帮助记得给我一个推荐或点赞哦

参考:

TCP的握手和挥手的更多相关文章

  1. 关于TCP的握手与挥手-----简单解释

    所谓三次握手(Three-Way Handshake)即建立TCP连接,就是指建立一个TCP连接时,需要客户端和服务端总共发送3个包以确认连接的建立.在socket编程中,这一过程由客户端执行conn ...

  2. TCP的握手与挥手

    轻轻的TCP走了,正如TCP轻轻的来,TCP挥一挥手,传递了不知多少信息 看到哪,记到哪,想起哪,就看哪,这就是我的博客园,很随性 ---------------------------------- ...

  3. TCP 握手和挥手图解(有限状态机)

    1.引言 TCP 这段看过好几遍,老是记不住,没办法找工作涉及到网络编程这块,各种问 TCP .今天好好整理一下握手和挥手过程.献给跟我一样忙碌,找工作的童鞋,欢迎大神批评指正. 2.TCP 的连接建 ...

  4. TCP/IP握手协议

    转自:http://www.js123.net/t/n/n/2013/4/28/n_272.shtml 这篇介绍的也很棒:http://www.cnblogs.com/rootq/articles/1 ...

  5. 两将军问题、拜占庭将军问题、TCP三路握手过程的联系

    2015年初时产生了一个疑问:基于不可靠的通信链路,为什么在两将军问题中永远无法达到共识,而在TCP三路握手中可以? 今天抽出了一些时间进行研究发现,实际上TCP三路握手也不是完全可靠的,只是一个近似 ...

  6. TCP模型,控制标志,握手,挥手,长连接*

    1. TCP协议 Transmission Control Protocol,传输控制协议 面向连接的协议 需要三次握手建立连接 需要四次挥手断开连接 TCP报头最小长度:20字节 2.模型图 3.T ...

  7. TCP/IP 3握手4挥手

    转:摘自<图解TCP/IP>P204 三次握手与四次挥手的状态转移图如下: 如图,由于第二次握手接收端发送SYN+ACK信号所以握手只用了三次,挥手由于接收端ACK和FIN分两次发的,所以 ...

  8. UNP——第二章,TCP握手与挥手分析

    1.握手 说明: 下面涉及 FIN,SYN,ACK之类数据时,都是由TCP服务收发, 涉及 accept, listen 之类api,都是 应用进程 完成. 都统一使用 客户端,服务端描述,请自行分辨 ...

  9. 抓包分析 TCP 握手和挥手

    前言 首先需要明确的是 TCP 是一个可靠传输协议,它的所有特点最终都是为了这个可靠传输服务.在网上看到过很多文章讲 TCP 连接的三次握手和断开连接的四次挥手,但是都太过于理论,看完感觉总是似懂非懂 ...

随机推荐

  1. 001-Java学习前基础

    目录 前言 一.Java语言特性(简单概述) 二.JDK.JRE.JVM三者关系 三.java文件的加载与执行 前言 初次在博客园写博客,想通过这种方式把自己学过的东西梳理一遍,加深自己的记忆,笔记中 ...

  2. KeyError:‘uid' Python常见错误

    使用不存在的字典键值 检查字典和要查的内容 如有不正确改正即可

  3. HTML5-本地存储浅谈

    Web Storage是HTML5里面引入的一个类似于cookie的本地存储功能,可以用于客户端的本地存储 sessionStorage && localStorage session ...

  4. 消息队列高手课,带你从源码角度全面解析MQ的设计与实现

    消息队列中间件的使用并不复杂,但如果你对消息队列不熟悉,很难构建出健壮.稳定并且高性能的企业级系统,你会面临很多实际问题: 如何选择最适合系统的消息队列产品? 如何保证消息不重复.不丢失? 如果你掌握 ...

  5. 给出N个字符串恰好由三位字母(大小写)组成,再给出M个查询字符串,问每个查询字符串在N个字符中出现的次数。

    1 #include<cstdio> 2 const int maxn = 100; 3 char S[maxn][5], temp[5]; 4 int hashTable[52 * 52 ...

  6. redis的并发竞争问题是什么?如何解决这个问题?

    这个也是线上非常常见的一个问题,就是多客户端同时并发写一个key,可能本来应该先到的数据后到了,导致数据版本错了.或者是多客户端同时获取一个key,修改值之后再写回去,只要顺序错了,数据就错了. 而且 ...

  7. JetBrains系列IDE无法输入中文

    1 问题描述 环境Linux+fcitx,JetBrains的IDE无法输入中文,包括IDEA,PyCharm,WebStorm,CLion等等. 2 解决方案 Linux下一般使用fcitx进入中文 ...

  8. linux 在某个路径下,查找某个文件

    find /cephfs/netdisk/ -name "*.sql"

  9. 闲暇时光里最好的挖矿体验——CPU挖乌龟币

    我之前其实是不玩加密货币的,主要是没有钱取投资(tou ji),也没有钱去投资矿机. 不过前几天CSDN推送了一个短文,<黑客用GitHub服务器挖矿,三天跑了3万个任务,代码惊现中文> ...

  10. day10.闭包函数与装饰器

    一.闭包函数 1.闭函数:被封闭起来的函数==>定义在函数内部的函数,特点是只能在函数内调用 2.包函数:该函数引用了一个名字,该名字来自于E这一层 总结:闭包函数指的是定义在函数内部的函数引用 ...