博客
关于我
三次握手四次挥手小结
阅读量:355 次
发布时间:2019-03-04

本文共 796 字,大约阅读时间需要 2 分钟。

连接小结 :

刚开始双方TCP进程都处于关闭状态(closed),客户主动打开连接,服务器被动打开连接,服务器处于收听状态(listen 状态),等待客户连接请求。

  1. 客户端向服务器发出连接请求报文段:SYN=1seq = x

    TCP客户端进入同步已发送状态(SYN_Send)。

  2. 服务器的TCP收到连接请求报文后,发送确认报文段,SYN=1,ACK =1,ack =x+1 ,seq =y

    TCP服务器进入TCP同步接收状态(SYN_REVD ),使用半连接队列

  3. TCP客户端收到确认报文后还要向服务器给出确认,其ACK=1,ack=y+1seq=x+1

    客户端进入已连接状态(establised )。

    服务器收到确认后也进入已连接状态(establised )。

    主动建立连接的客户端两个状态,被动建立连接的服务端三个状态

释放小结

刚开始都处于建立状态(ESTAB-LISHEN)

  1. 客户端先发出连接释放报文段,并停止再发送数据,主动关闭TCP连接。

    FIN=1,seq=u

    客户端进入终止等待状态FIN_WAIT1),等待服务器的确认。

  2. 服务器收到连接释放报文段后,发送确认ACK=1ack=u+1,seq=v

    服务器处于关闭等待状态CLOSE_WAIT

    客户端收到确认依然在终止等待FIN_WAIT2

  3. 若服务器也要断开,就发送TCP连接释放报文。FIN=1,ACK=1,ack=u+1,seq=w

    服务器进入最终确认状态LAST_ACK),等待A的确认。

  4. 客户端在收到服务器的连接释放报文段后必须对其确认,ACK=1,ack=w+1,seq=u+1

    客户端进入时间等待状态TIME_WAIT)。需要过一阵子以确保服务端收到自己的 ACK 报文之后才会进入关闭状态 (CLOSED )。

  5. 服务端收到 ACK 报文之后,就处于关闭状态( CLOSED)。

转载地址:http://tbfr.baihongyu.com/

你可能感兴趣的文章
mysql查询输出到excel文件_如何保存mysql查询输出到excel或.txt文件?
查看>>
mysql查询过程
查看>>
MySQL模拟Oracle序列sequence
查看>>
Mysql模糊查询like效率,以及更高效的写法
查看>>
MySQL死锁套路:一次诡异的批量插入死锁问题分析
查看>>
Mysql死锁问题Deadlock found when trying to get lock;try restarting transaction
查看>>
mysql每个数据库的最大连接数_MySQL数据库最大连接数
查看>>
Mysql流程控制结构,if函数、case结构、if结构、循环结构
查看>>
mysql添加外网访问权限
查看>>
mysql添加用户
查看>>
MySQL添加用户、删除用户与授权
查看>>
mysql添加用户及权限
查看>>
Mysql添加用户并授予只能查询权限
查看>>
mysql添加用户权限报1064 - You have an error in your SQL syntax问题解决
查看>>
mysql添加索引
查看>>
mysql添加表注释、字段注释、查看与修改注释
查看>>
mysql清理undo线程_MySQL后台线程的清理工作
查看>>
mysql清空带外键的表
查看>>
MySQL清空表数据
查看>>
mysql源码安装
查看>>