0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

TCP三次握手过程及四次挥手过程说明

电子设计 来源:51CTO 作者:51CTO 2021-03-01 12:00 次阅读

三次握手
置位概念:根据 TCP 的包头字段,存在 3 个重要的标识 ACK、SYN、FIN

ACK:表示验证字段 SYN:位数置 1,表示建立 TCP 连接 FIN:位数置 1,表示断开 TCP 连接

三次握手过程说明:

1. 由客户端发送建立 TCP 连接的请求报文,其中报文中包含 seq 序列号,是由发送端随机生成的,并且将报文中的 SYN 字段置为 1,表示需要建立 TCP 连接。(SYN=1,seq=x,x 为随机生成数值)2. 由服务端回复客户端发送的 TCP 连接请求报文,其中包含 seq 序列号,是由回复端随机生成的,并且将 SYN 置为 1,而且会产生 ACK 字段,ACK 字段数值是在客户端发送过来的序列号 seq 的基础上加 1 进行回复,以便客户端收到信息时,知晓自己的 TCP 建立请求已得到验证。(SYN=1,ACK=x+1,seq=y,y 为随机生成数值)这里的 ack 加 1 可以理解为是确认和谁建立连接。3. 客户端收到服务端发送的 TCP 建立验证请求后,会使自己的序列号加 1 表示,并且再次回复 ACK 验证请求,在服务端发过来的 seq 上加 1 进行回复。(SYN=1,ACK=y+1,seq=x+1)

四次挥手

四次挥手过程说明:

1. 客户端发送断开 TCP 连接请求的报文,其中报文中包含 seq 序列号,是由发送端随机生成的,并且还将报文中的 FIN 字段置为 1,表示需要断开 TCP 连接。(FIN=1,seq=x,x 由客户端随机生成)2. 服务端会回复客户端发送的 TCP 断开请求报文,其包含 seq 序列号,是由回复端随机生成的,而且会产生 ACK 字段,ACK 字段数值是在客户端发过来的 seq 序列号基础上加 1 进行回复,以便客户端收到信息时,知晓自己的 TCP 断开请求已经得到验证。(FIN=1,ACK=x+1,seq=y,y 由服务端随机生成)3. 服务端在回复完客户端的 TCP 断开请求后,不会马上进行 TCP 连接的断开,服务端会先确保断开前,所有传输到 A 的数据是否已经传输完毕,一旦确认传输数据完毕,就会将回复报文的 FIN 字段置 1,并且产生随机 seq 序列号。(FIN=1,ACK=x+1,seq=z,z 由服务端随机生成)4. 客户端收到服务端的 TCP 断开请求后,会回复服务端的断开请求,包含随机生成的 seq 字段和 ACK 字段,ACK 字段会在服务端的 TCP 断开请求的 seq 基础上加 1,从而完成服务端请求的验证回复。(FIN=1,ACK=z+1,seq=h,h 为客户端随机生成)

至此 TCP 断开的 4 次挥手过程完毕

11 种状态

o4YBAF-hUzCAN2AHAALJib3CKH0491.png

1. 一开始,建立连接之前服务器和客户端的状态都为 CLOSED;2. 服务器创建 socket 后开始监听,变为 LISTEN 状态;3. 客户端请求建立连接,向服务器发送 SYN 报文,客户端的状态变味 SYN_SENT;4. 服务器收到客户端的报文后向客户端发送 ACK 和 SYN 报文,此时服务器的状态变为 SYN_RCVD;5. 然后,客户端收到 ACK、SYN,就向服务器发送 ACK,客户端状态变为 ESTABLISHED;6. 服务器端收到客户端的 ACK 后变为 ESTABLISHED。此时 3 次握手完成,连接建立!

o4YBAF-hUzWAT1s-AALppBezJkQ503.png

由于 TCP 连接是全双工的,断开连接会比建立连接麻烦一点点。

1. 客户端先向服务器发送 FIN 报文,请求断开连接,其状态变为 FIN_WAIT1;2. 服务器收到 FIN 后向客户端发送 ACK,服务器的状态围边 CLOSE_WAIT;3. 客户端收到 ACK 后就进入 FIN_WAIT2 状态,此时连接已经断开了一半了。如果服务器还有数据要发送给客户端,就会继续发送;4. 直到发完数据,就会发送 FIN 报文,此时服务器进入 LAST_ACK 状态;5. 客户端收到服务器的 FIN 后,马上发送 ACK 给服务器,此时客户端进入 TIME_WAIT 状态;6. 再过了 2MSL 长的时间后进入 CLOSED 状态。服务器收到客户端的 ACK 就进入 CLOSED 状态。

至此,还有一个状态没有出来:CLOSING 状态。

CLOSING 状态表示: 客户端发送了 FIN,但是没有收到服务器的 ACK,却收到了服务器的 FIN,这种情况发生在服务器发送的 ACK 丢包的时候,因为网络传输有时会有意外。

•LISTEN:等待从任何远端 TCP 和端口的连接请求。•SYN_SENT:发送完一个连接请求后等待一个匹配的连接请求。•SYN_RECEIVED:发送连接请求并且接收到匹配的连接请求以后等待连接请求确认。•ESTABLISHED:表示一个打开的连接,接收到的数据可以被投递给用户。连接的数据传输阶段的正常状态。•FIN_WAIT_1:等待远端 TCP 的连接终止请求,或者等待之前发送的连接终止请求的确认。•FIN_WAIT_2:等待远端 TCP 的连接终止请求。•CLOSE_WAIT:等待本地用户的连接终止请求。•CLOSING:等待远端 TCP 的连接终止请求确认。•LAST_ACK:等待先前发送给远端 TCP 的连接终止请求的确认(包括它字节的连接终止请求的确认)•TIME_WAIT:等待足够的时间过去以确保远端 TCP 接收到它的连接终止请求的确认。•TIME_WAIT 两个存在的理由:•可靠的实现 tcp 全双工连接的终止;•允许老的重复分节在网络中消逝。•CLOSED:不在连接状态(这是为方便描述假想的状态,实际不存在)

编辑:hfy

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 服务器
    +关注

    关注

    12

    文章

    8933

    浏览量

    85049
  • TCP
    TCP
    +关注

    关注

    8

    文章

    1346

    浏览量

    78909
收藏 人收藏

    评论

    相关推荐

    讲一讲的TCP三次握手四次挥手

    如果你学过网络基础知识,那么你一定对TCP三次握手不陌生。今天我想用通俗的话来给大家讲一讲TCP三次握手
    的头像 发表于 02-03 10:43 2665次阅读
    讲一讲的<b class='flag-5'>TCP</b><b class='flag-5'>三次</b><b class='flag-5'>握手</b>和<b class='flag-5'>四次</b><b class='flag-5'>挥手</b>

    TCP恋爱史:三次握手四次分手

    ,心想:我他妈又没要链接,你返回这个是不是疯了。于是不置一词。服务器过一段时间还没有收到第三次握手的数据,知道客户端并没有要求建立链接的请求,含泪离开。然后是四次分手:现在双方的状态都是
    发表于 09-28 10:07

    三次握手四次挥手你懂吗

    程序员面试被问到“三次握手四次挥手”怎么办?
    发表于 04-08 07:23

    TCP三次握手过程描述

    本文档主要描述TCP三次握手过程,一个完整的三次握手也就是 请求---应答---再次确认
    发表于 03-02 15:37 8次下载

    tcp协议三次握手详细过程

    TCP是主机对主机层的传输控制协议,提供可靠的连接服务,采用三次握手确认建立一个连接:第一握手:主机A发送位码为syn=1,随机产生seq
    发表于 12-08 11:53 9883次阅读
    <b class='flag-5'>tcp</b>协议<b class='flag-5'>三次</b><b class='flag-5'>握手</b>详细<b class='flag-5'>过程</b>

    TCP/IP协议工作过程三次握手四次挥手

    )、第三次握手:Client收到确认后,检查ACK是否为1,如果正确则将标志位ACK置为1,并将该数据包发送给Server,Server检查ACK是否为1,如果正确则连接建立成功,Client
    的头像 发表于 10-25 09:49 6941次阅读

    TCP三次握手四次挥手以及11种状态资料下载

    电子发烧友网为你提供TCP三次握手四次挥手以及11种状态资料下载的电子资料下载,更有其他相关的电路图、源代码、课件教程、中文资料、英文资料
    发表于 04-15 08:41 2次下载
    <b class='flag-5'>TCP</b><b class='flag-5'>三次</b><b class='flag-5'>握手</b>和<b class='flag-5'>四次</b><b class='flag-5'>挥手</b>以及11种状态资料下载

    TCP三次握手四次挥手过程中的异常情况

    TCP 三次握手四次挥手过程中,途中某一步的报文丢失了,会发生什么?
    的头像 发表于 09-05 10:23 1195次阅读

    如何使用WireShark进行TCP三次握手

    WireShark是一种非常方便的网络抓包工具,下面演示,使用WireShark来抓取TCP三次握手过程
    的头像 发表于 11-01 09:50 2078次阅读

    通过WireShark抓取TCP三次握手过程分享

    客户端收到服务器的响应后,就会回复一个序列号为Seq = c+1, 确认号为Ack = s+1的ACK数据包给服务器,三次握手完成。
    发表于 11-01 09:49 2196次阅读

    TCP建立连接概述及三次握手四次挥手的流程

    具备上述个条件后A获取B的信息是有要求的,根本上的要求是数据信道可靠,就是平时所说的可靠连接,那么如何保证连接的可靠性呢,TCP协议就是靠确认应答机制、超时重传机制等保证连接可靠性的,接下来就通过TCP协议的
    的头像 发表于 03-23 15:57 1026次阅读
    <b class='flag-5'>TCP</b>建立连接概述及<b class='flag-5'>三次</b><b class='flag-5'>握手</b>、<b class='flag-5'>四次</b><b class='flag-5'>挥手</b>的流程

    用恋爱的方式解释TCP三次握手四次挥手

    前言今天的分享,是关于前两天读到的心得,TCP建立连接时三次握手,断开时为何4握手的自我理解:恋爱时连接时客户端说:SYN(约吗?)服务器
    的头像 发表于 08-28 16:11 657次阅读
    用恋爱的方式解释<b class='flag-5'>TCP</b>的<b class='flag-5'>三次</b><b class='flag-5'>握手</b>和<b class='flag-5'>四次</b><b class='flag-5'>挥手</b>

    关于TCP协议总结的硬核干货

    本文给出TCP报文格式的详细说明,介绍网络数据包传递中如何进行地址解析、建立TCP连接的三次握手过程
    发表于 11-17 09:26 443次阅读
    关于<b class='flag-5'>TCP</b>协议总结的硬核干货

    说说TCP三次握手过程?为什么是三次而不是两四次

    说说TCP三次握手过程?为什么是三次而不是两四次
    的头像 发表于 02-04 11:03 566次阅读

    简述TCP协议的三次握手机制

    机制是建立一个可靠的连接的关键步骤。以下是对TCP协议三次握手机制的介绍: 概述 TCP协议的三次握手
    的头像 发表于 08-16 10:57 472次阅读