博客
关于我
三次握手四次挥手小结
阅读量: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如何做到存在就更新不存就插入_MySQL 索引及优化实战(二)
查看>>
mysql如何删除数据表,被关联的数据表如何删除呢
查看>>
MySQL如何实现ACID ?
查看>>
mysql如何记录数据库响应时间
查看>>
MySQL子查询
查看>>
Mysql字段、索引操作
查看>>
mysql字段的细节(查询自定义的字段[意义-行列转置];UNION ALL;case-when)
查看>>
mysql字段类型不一致导致的索引失效
查看>>
mysql字段类型介绍
查看>>
mysql字段解析逗号分割_MySQL逗号分割字段的行列转换技巧
查看>>
MySQL字符集与排序规则
查看>>
MySQL字符集乱码
查看>>
mysql字符集设置
查看>>
mysql存储IP地址的数据类型
查看>>
mysql存储中文 但是读取乱码_mysql存储中文乱码
查看>>
MySQL存储引擎
查看>>
MySQL存储引擎--MYSIAM和INNODB引擎区别
查看>>
Mysql存储引擎(2):存储引擎特点
查看>>
MySQL存储引擎--MyISAM与InnoDB区别
查看>>
mysql存储总结
查看>>