博客
关于我
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中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>
mysql中的rbs,SharePoint RBS:即使启用了RBS,内容数据库也在不断增长
查看>>
mysql中的undo log、redo log 、binlog大致概要
查看>>
Mysql中的using
查看>>
MySQL中的关键字深入比较:UNION vs UNION ALL
查看>>
mysql中的四大运算符种类汇总20多项,用了三天三夜来整理的,还不赶快收藏
查看>>