博客
关于我
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/

你可能感兴趣的文章
WAP短信:融合传统短信和互联网的新型通信方式
查看>>
mysql面试题学校三表查询_mysql三表查询分组后取每组最大值,mysql面试题。
查看>>
Mysql面试题精选
查看>>
MySQL面试题集锦
查看>>
mysql面试题,存储引擎InnoDB和MyISAM
查看>>
mysql面试题:为什么MySQL单表不能超过2000W条数据?
查看>>
mysql面试题:创建索引时会不会锁表?
查看>>
mysql面试题:高度为3的B+树可以存放多少数据?
查看>>
mysql颠覆实战笔记(八)--mysql的自定义异常处理怎么破
查看>>
mysql驱动、durid、mybatis之间的关系
查看>>
mysql驱动支持中文_mysql 驱动包-Go语言中文社区
查看>>
MySQL高可用之——keepalived+互为主从
查看>>
MySQL高可用切换_(5.9)mysql高可用系列——正常主从切换测试
查看>>
MySQL高可用解决方案
查看>>
MySQL高可用解决方案详解
查看>>
MYSQL高可用集群MHA架构
查看>>
MySQL高可用集群架构MHA企业级实战
查看>>
MySQL高级-MySQL存储引擎
查看>>
MySQL高级-MySQL并发参数调整
查看>>
MySQL高级-MySQL应用优化
查看>>