博客
关于我
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 in 太多过慢的 3 种解决方案
查看>>
MySQL InnoDB 三大文件日志,看完秒懂
查看>>
Mysql InnoDB 数据更新导致锁表
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>
Mysql InnoDB存储引擎 —— 数据页
查看>>
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>
Mysql order by与limit混用陷阱
查看>>
Mysql order by与limit混用陷阱
查看>>
mysql order by多个字段排序
查看>>