TCP
状态有几种?
通常情况下我们说的 TCP
包状态实际上是 TCP
标志位,目前TCP
标志位主要有以下有6种:
名称 | 英文 | 中文 | 详细说明 |
---|---|---|---|
SYN | synchronous | 同步 | 建立连接,同步状态 |
ACK | acknowledgement | 确认 | 确认上一个包已收到(确认收到) |
PSH | push | 推 | 发送数据 |
FIN | finish | 结束 | 连接结束,不需要发送数据了 |
RST | reset | 重置 | 重置连接状态(重新连接) |
URG | urgent | 紧急 | TCP 带外数据相关,基本不会用到 |
其中URG 在实际使用中属于百年一见的类型,所以我们就不与介绍了,主要介绍这些常见的TCP 标志位。 |
|||
# 一次正常的TCP 连接都会发送那些包? |
|||
接下来,我们通过看一个完整的TCP 交互都有哪些流程,对应包又是什么样。 |
|||
1. 建立连接 | |||
客户端操作 | 包 | 方向 | 包 |
:– | :– | :– | :– |
connect | SYN | >>>>>> | |
connect | <<<<<< | SYN,ACK | |
connect_end | ACK | >>>>>> | |
2. 服务器读,客户端写 | |||
客户端操作 | 包 | 方向 | 包 |
:– | :– | :– | :– |
write | PSH | >>>>>> | |
write_end | <<<<<< | ACK | |
3. 客户端读,服务器写 | |||
客户端操作 | 包 | 方向 | 包 |
:– | :– | :– | :– |
<<<<<< | |||
ACK | >>>>>> | ||
read | |||
4. 服务端断开连接 | |||
客户端操作 | 包 | 方向 | 包 |
:– | :– | :– | :– |
<<<<<< | |||
ACK | >>>>>> | ||
6. 客户端断开连接 | |||
客户端操作 | 包 | 方向 | 包 |
:– | :– | :– | :– |
shutdown | FIN | >>>>>> | |
<<<<<< | |||
7. 服务器,客户端双方释放本地资源(内存,句柄等) | |||
客户端操作 | 包 | 方向 | 包 |
:– | :– | :– | :– |
close(释放资源) |
socket
方法和TCP
包的对应关系是什么?
知道了一个完整的TCP交互流程后,就可以尝试总结一下 socket
方法和 TCP
包的对应关系了。
注意:下表内容不绝对正确,只是通过这种方式来辅助理解。
操作| 发出的包| 需要的回复|
:–|:–|:–|
connect| SYN| ACK|
read |无 |PSH|
write| PSH |ACK|
shutdown| FIN| ACK|
close(读写缓冲区无数据) |无| 无|
close(读写缓冲区有数据)| RST| 无|
处理过程中特殊情况怎么处理?
当然,仅仅知道操作和包的对应关系还不够,因为显示中还会存在一些其他状况,下面这个表格就列举了一部分特殊情况,可以帮助你更好的了解相关问题。
现象| 错误信息| Error info|
:–|:–|:–|
当连接的机器端口没有服务器的时候,机器会回复 RST 包 |连接被拒绝| Contection refused|
当任何一步操作没有收到回复包的时候会根据情况产生超时| xxx操作超时 |xxx timeout|
当任何一步操作收到 RST 包的时候会产生错误 |连接被重置 |Connection was reset|
当一方收到 FIN 包后,则收到的一方调用read是会返回长度0,但没有错误| 无 |
当调用close时,如果读写缓冲区里没有数据则close会先调用shutdown方法 |无 |
当调用close时,如果读写缓冲区里有数据则close会回复 RST 包 |连接被重置 |Connection was reset|
拓展
可以尝试回答下面的问题,来确认自己对上面内容的理解程度。
问题|
:–|
客户端连接成功后,服务器网线断了,客户端read返回什么?|
客户端连接成功后,服务器正常调用shutdown关闭连接,客户端read返回什么?|