在各种网络异常情况的背后,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。以ubuntu 12.04为例,重发SYN的时间,系列是:
0,1,3,7,15,31,63(