博客
关于我
三次握手四次挥手小结
阅读量: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学习总结(53)——使用MySql开发的Java开发者规范
查看>>
Mysql学习总结(54)——MySQL 集群常用的几种高可用架构方案
查看>>
Mysql学习总结(55)——MySQL 语句大全再温习
查看>>
Mysql学习总结(56)——MySQL用户管理和权限设置
查看>>
Mysql学习总结(57)——MySQL查询当天、本周、本月、上周、本周、上月、距离当前现在6个月数据
查看>>
Mysql学习总结(58)——深入理解Mysql的四种隔离级别
查看>>
Mysql学习总结(59)——数据库分库分表策略总结
查看>>
Mysql学习总结(5)——MySql常用函数大全讲解
查看>>
Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
查看>>
Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
查看>>
Mysql学习总结(62)——MySQL连接com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link问题
查看>>
Mysql学习总结(63)——Mysql数据库架构方案选择与分析
查看>>
Mysql学习总结(64)——Mysql配置文件my.cnf各项参数解读
查看>>
Mysql学习总结(65)——项目实战中常用SQL实践总结
查看>>
Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
查看>>
Mysql学习总结(67)——MYSQL慢查询日志
查看>>
Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
查看>>
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
Mysql学习总结(70)——MySQL 优化实施方案
查看>>