博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
TCP三路握手
阅读量:4616 次
发布时间:2019-06-09

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

 

建立一个TCP连接时回发生下述情形

(1)服务器必须准备好接受外来的连接。这通常通过调用socket,bind,和listen这三个函数来完成,我们称之为被动打开(passive open)

(2)客户通过调用connect发起主动打开(active open)。这导致客户TCP发送一个SYN(同步)分节,他告诉服务器客户将在(待建立的)连接中发送的数据的初始序列号。通常SYN分节不携带数据,其所在IP数据包只含有一个IP首部,一个TCP首部以及可能有的TCP选项

(3)服务器必须确认(ACK)客户的SYN,同时自己也得发送一个SYN分节,它含有服务器将在同一连接中发送的数据的初始序列号。服务器在单个分节发送SYN和对客户SYN的确认(ACK)

(4)客户必须确认服务器的SYN

 

这种交换至少需要三个分组,因此称之为TCP的三路握手(three-way handshake)

 

图中给出的客户的初始序列号为J,服务器的初始序列号为K。ACK中的确认号是发送这个ACK的一端所期待的下一个序列号。因为SYN占据一个字节的序列号空间。所以每个SYN的ACK中的确认号就是该SYN的初始序列号加1.类似的,每一个FIN(表示结束)的ACK中的确认号为该FIN的序列号加1.

转载于:https://www.cnblogs.com/isohybrid/archive/2013/03/01/three-way_handshake.html

你可能感兴趣的文章
linux常用端口
查看>>
异常处理
查看>>
/proc/uptime详解
查看>>
如何建立合适的索引?
查看>>
acwing 651. 逛画展
查看>>
Vijos P1243 生产产品 (单调队列优化DP)
查看>>
iOS常用第三方库 -转
查看>>
Android布局学习
查看>>
python的沙盒环境--virtualenv
查看>>
软件自动化测试——入门、进阶与实战
查看>>
BZOJ1878 [SDOI2009]HH的项链 树状数组 或 莫队
查看>>
BZOJ3675 [Apio2014]序列分割 动态规划 斜率优化
查看>>
2016.10.24 继续学习
查看>>
产品功能对标 - 服务授权管理
查看>>
各地IT薪资待遇讨论
查看>>
splay入门
查看>>
带CookieContainer进行post
查看>>
C语言学习笔记--字符串
查看>>
CSS-上下文选择器
查看>>
ionic repeat 重复最后一个时要执行某个函数
查看>>