在各种网络异常情况的背后,TCP是怎么处理的?又是怎样把处理结果反馈给上层应用的?本文就来讨论这个问题。

分为两个场景来讨论
建立连接
1 正常情况下
进过三次握手,客户端连接成功,服务端有一个新连接到来。
2 客户端连接了服务端未监听的端口
在这种情况下,服务端会对收到的SYN回应一个RST(RFC 793 3.4),客户端收到RST之后,终止连接,并进入CLOSED状态。
客户端的connect返回
ECONNREFUSED 111 /* Connection refused *
/。
3 客户端与服务器之间的网络不通
这又分两种情况
- connect返回主机不可达
具体信息在不同系统上不一样,比如linux上的定义是EHOSTUNREACH 113 /* No route to host */。明显给出了一个不可访问的地址(例如,访
问一个不存在的本地网络地址,或者DNS解析失败会导致这种情况。 - connect返回连接超时
这种情况下,客户端发送的SYN丢失在网络中,没有得到确认,客户端的TCP会超时重发SYN。

本文详细探讨了TCP连接的异常情况,包括客户端连接服务端未监听端口、网络不通、连接过程中包丢失等问题,以及通信过程中的网络断开、一方崩溃等情况,分析了各种异常下的响应和处理机制。
最低0.47元/天 解锁文章
2149

被折叠的 条评论
为什么被折叠?



