博客
关于我
TCP三次握手四次挥手
阅读量:697 次
发布时间:2019-03-15

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

TCP三次握手四次挥手

一、从TCP报文段内容上

  • 序号seq:32bit,4字节, 用来标记数据段的顺序 ,TCP把数据看成无结构、有顺序的字节流。

    TCP把连接中发送的所有数据字节都编上一个序号,第一个字节的编号由本地随机产生;给字节编上序号后,就给每一个报文段指派一个序号。

    序列号seq就是这个报文段中的第一个字节的数据编号。

  • 确认号ack:32bit,4字节, 期待收到对方下一个报文段的第一个数据字节的序号 。

    序列号表示报文段携带数据的第一个字节的编号;而确认号指的是期望接收到下一个字节的编号;因此当前报文段最后一个字节的编号+1即为确认号。

  • 确认ACK: 占1位,仅当ACK=1时,确认号字段才有效。ACK=0时,确认号无效 。

发起SYN:发起创建连接。

终止FIN:发起拆除连接。

另外 接收窗口或窗口是进行流量控制的,指定接收的字节数量

在这里插入图片描述

二、三次握手

C S
SYN=1=》通知建立连接; seq=client_isn=》随机初始序号。
ACK=1=》确认收到 SYN=1;ack=client_isn+1=》希望客户端下次发送的下一个字节的序号;seq=server_isn=》指定服务器发送报文段初始序号;
ACK=1;SYN=0=》连接已建立; seq=client_isn+1=》发送报文段第一个字节的序号;ack=server_isn+1=》希望服务端发送的下一个报文段第一个字节的序号;

为什么需要三次握手而不是两次或四次

TCP三次握手是为了确定双方数据原点的序号!!!

两次

C S
SYN=1;seq=x
ACK=1;SYN=1;seq=y;ack=x+1=》确C的序列化
没有ack无法确定S的序列号

四次

C S
SYN=1;seq=x
ACK=1;ack=x+1;
SYN=1;seq=y//二三步可以合并
ACK=1;ack=y+1;seq=x+1

三、四次挥手

C S
Fin=1=》拆除客户端连接; seq=x=》最后的server ack;
ACK=1;seq=z;ack=x+1;
Fin=1=》拆除服务端连接;seq=Y;ack=x+1;
ACK=1;seq=x+1; ack=Y+1;

四、参考

https://mp.weixin.qq.com/s/NIjxgx4NPn7FC4PfkHBAAQ

可能访问不了。

图片是老师ppt上的本来想自己画一个但是画图网站登录不了了。

四次挥手为什么是四次,下一篇。

内容如有错误不吝赐教,感谢。

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

你可能感兴趣的文章
Mysql分表后同结构不同名称表之间复制数据以及Update语句只更新日期加减不更改时间
查看>>
mySql分页Iimit优化
查看>>
MySQL分页查询
查看>>
mysql列转行函数是什么
查看>>
mysql创建函数报错_mysql在创建存储函数时报错
查看>>
mysql创建数据库和用户 并授权
查看>>
mysql创建数据库指定字符集
查看>>
MySql创建数据表
查看>>
MySQL创建新用户以及ERROR 1396 (HY000)问题解决
查看>>
MySQL创建用户与授权
查看>>
MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>
mysql初始密码错误问题
查看>>
Mysql删除重复数据通用SQL
查看>>
mysql判断某一张表是否存在的sql语句以及方法
查看>>
mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
查看>>
mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>
mysql加强(3)~分组(统计)查询
查看>>
mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
查看>>
mysql加强(5)~DML 增删改操作和 DQL 查询操作
查看>>