TCP协议的三次握手, 四次挥手

 三次握手过程

  1, 服务器时刻准备接受客户端进程的连接请求, 此时服务器就进入了LISTEN(监听)状态;

  2, 客户端进程然后向服务器发出连接请求报文, 之后客户端进程进入了 SYN-SENT(同步已发送状态)状态;

  3, 服务器收到请求报文后, 如果同意连接, 则发出确认报文, 此时, 服务器进程进入了SYN-RCVD(同步收到)状态;

  4, 客户端进程收到确认后, 还要向服务器给出确认. 此时, 客户端进入ESTABLISHED(已建立连接)状态;

  5, 当服务器收到客户端的确认后也进入ESTABLISHED状态, 此后双方就可以开始通信了.

  举个列子:

    A: " 喂我是A, 你能听到我讲话吗? " (客户端发起连接请求)

    B: " 听到了, 我是B, 那你能听到我讲话吗? "  (服务端接收到请求, 同意连接后向客户端发出确认报文)

    A: " 嗯嗯, 我能听得到. "  (客户端收到服务端发出的确认报文后, 给出确认, 表明客户端处于连接已建立状态)

    B: " ...... "  (服务端收到客户端的确认后, 也进入连接已建立状态)

 

 四次挥手过程:

  数据传输完毕后,双方都可释放连接。最开始的时候,客户端和服务器都是处于ESTABLISHED状态,然后客户端主动关闭,服务器被动关闭。

  1, 客户端进程发出连接释放报文,并且停止发送数据. 此时,客户端进入FIN-WAIT-1(终止等待1)状态;

  2, 服务器收到客户端的连接释放报文,服务器发出确认报文, 此时,服务端就进入了CLOSE-WAIT(关闭等待)状态(此时客户端已经没有数据要发送了, 但是服务器若发送数据, 客户端依然要接受);

  3, 客户端收到服务器的确认请求后, 客户端就进入FIN-WAIT-2(终止等待2)状态, 等待服务器发送连接释放报文(在这之前还要接受服务器发送的最后数据);

  4, 服务器发送完最后的数据后, 就向客户端发送连接释放报文, 此时,服务器就进入了LAST-ACK(最后确认)状态, 等待客户端的最后确认;

  5, 客户端收到服务器的连接释放报文后, 必须发出确认, 此时客户端就进入了TIME-WAIT ( 时间等待 )状态(此时连接还没有释放, 必须经过2∗∗MSL(最长报文段寿命)的时间后, 当客户端撤销相应的TCB连接后,才进入CLOSED状态)。

  6, 服务器只要收到了客户端发出的确认,立即进入CLOSED状态(服务器结束TCP连接的时间要比客户端早一些)。

  举个例子:

    A: " 喂, 我不说了, 我要挂电话了 "  (客户端发出连接释放请求, 客户端并且停止发送数据)

    B: " 嗯我知道, 我刚才那句话还没说完 "  (服务器收到客户端的连接释放报文, 并发出确认报文给客户端, 表示服务器收到请求了)

    B: " 好了, 说完了, 我不说了 "  (服务器在发送完最后的数据后, 给客户端发出最后连接释放报文, 服务器等待客户端的最后确认)

    A: " 我知道了 "  (客户端收到服务端的最后请求后并给出确认, 客户端经过2MSL时间后, 撤销TCP连接)

    B: 挂断电话....  (服务器收到客户端的最后确认后立即断开TCP连接)

符号说明

   Seq:"sequance"序列号
  Ack:"acknowledge"确认号
  SYN:"synchronize"请求同步标志
  ACK:"acknowledge"确认标志"
  FIN:"Finally"结束标志

python摸爬滚打之----tcp协议的三次握手四次挥手的更多相关文章

  1. OSI七层协议&TCP协议(三次握手四次挥手)

    今日内容 python 基础回顾 软件开发架构 网络理论前戏 OSI 七层协议(五层) TCP协议 三次握手与四次挥手 UDP协议 内容详细 一.python 基础回顾 1.基本数据类型 整型 int ...

  2. tcp协议:三次握手四次挥手详解-转

    https://www.cnblogs.com/welan/p/9925119.html

  3. 网络架构,七层协议,三次握手四次挥手,socket套接字简单编程

    一.单机架构 应用领域: 植物大战僵尸 office 二.CS架构 应用领域: QQ 大型网络游戏 计算机发展初期用户去取数据,直接就去主机拿,从这里开始就分出了客户端和服务端. 客户端:用户安装的软 ...

  4. web服务-1、http协议的三次握手四次挥手

    知识点:http协议:它是基于tcp协议的,浏览器访问服务器,服务器把资源回给浏览器,这个过程都是遵循http协议的,否则无法完成,http早些年是1.0版本,现在基本上都是1.1版本了,俩个版本的区 ...

  5. TCP/IP报文 三次握手 四次挥手

    1.TCP报文格式  TCP/IP协议的详细信息参看<TCP/IP协议详解>三卷本.下面是TCP报文格式图:图1 TCP报文格式  上图中有几个字段需要重点介绍下:  (1)序号:Seq序 ...

  6. 关于TCP传输的三次握手四次挥手策略

    简单小总结: 一般为了能够准确无误地把数据送达目标处,TCP协议采用了三次握手策略.用TCP协议把数据包送出去后,TCP不会对传送后的情况置之不理,它一定会向对方确认是否成功送达. 注:握手过程中使用 ...

  7. TCP传输的三次握手四次挥手策略

    为了准确无误地数据送达目标处,TCP协议采用了三次握手策略.用TCP协议把数据包送出去后,TCP不会对传送后的情况置之不理,它一定会向对方确认是否成功送达.握手中使用了TCP的标志:SYN和ACK 发 ...

  8. TCP/IP,三次握手四次挥手,TCP/UDP , HTTP/HTTPS

    internet:通用名词,由多个计算机网络组成的网络,网络间的通信协议是任意的 Internet:专用名词,当前全球最大的开放计算机网络,采用TCP/IP协议族作为通信的规则.www万维网是广泛应用 ...

  9. TCP连接为什么三次握手四次挥手

    前几天面试某电商被问住了,问的很细,我就说了说连接过程,必然凉凉.在csdn上找了一篇很详细的博客.https://blog.csdn.net/hyg0811/article/details/1023 ...

随机推荐

  1. HDU 2196 Compute --树形dp

    Computer Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  2. 【深度学习】吴恩达网易公开课练习(class2 week1 task2 task3)

    正则化 定义:正则化就是在计算损失函数时,在损失函数后添加权重相关的正则项. 作用:减少过拟合现象 正则化有多种,有L1范式,L2范式等.一种常用的正则化公式 \[J_{regularized} = ...

  3. C++面试

    C++ Primer.STL源码剖析.设计模式 C++ 析构函数可以是虚函数吗?为什么 构造函数可以是虚函数吗?为什么 如何防止类被继承 手写String类(实现类里面常用函) 什么是野指针如何避免这 ...

  4. sklearn模型的属性与功能-【老鱼学sklearn】

    本节主要讲述模型中的各种属性及其含义. 例如上个博文中,我们有用线性回归模型来拟合房价. # 创建线性回归模型 model = LinearRegression() # 训练模型 model.fit( ...

  5. tensorflow安装-【老鱼学tensorflow】

    TensorFlow是谷歌基于DistBelief进行研发的第二代人工智能学习系统,其命名来源于本身的运行原理.Tensor(张量)意味着N维数组,Flow(流)意味着基于数据流图的计算,Tensor ...

  6. 毕向东—Java基础知识总结(超级经典)

    Java基础知识总结(超级经典) 写代码: 1,明确需求.我要做什么? 2,分析思路.我要怎么做?1,2,3. 3,确定步骤.每一个思路部分用到哪些语句,方法,和对象. 4,代码实现.用具体的java ...

  7. [转自大神]js拖拽小总结

    https://blog.csdn.net/u013040887/article/details/83059094 权侵删 这里写的是一个原生js实现拖拽的效果,首先: 1.实现拖拽的三大事件,是要首 ...

  8. SDOI2019 省选前模板整理

    目录 计算几何✔ DP 斜率优化✔ 四边形不等式✔ 轮廓线DP✘ 各种分治 CDQ分治✔ 点分治✔ 整体二分✔ 数据结构 线段树合并✔ 分块✔ K-D Tree LCT 可持久化Trie✔ Splay ...

  9. python实现的跳点寻路算法(JPS)

    原理参考论文 代码已提交到git(https://github.com/YYRise/find_path/blob/master/jps.py)

  10. Grodno 2015 (Urozero May 2015 Day 5)

    A. Palindromes 留坑. B. Modules 将$a$排序,那么最优解中$a_n$一定放在前后一个,且前面$n-1$个每次要么放最小的,要么放最大的,区间DP即可. #include&l ...