基于TCP传输的网络编程异常处理
一:进程一端退出(exit,CTRL+C,挂掉)(跟主动CLOSE、主动关机一样)
内核会关闭所有句柄触发FIN分节发送(但如果设置了SO_LINGER l_onoff为1,则发送RST分节对方)
FIN分节处理: 另一端recv 返回0 表示对端结束
RST分节处理: 另一端recv 返回-1 表示对端错误,错误码为connection reset by peer
如果另一端send 则会导致进程接收SIGPIPE信号,该信号默认终止进程,
需要signal(SIGPIPE,SIG_IGN);
二:一端主机崩溃(非主动关机)、中间路由不通
另一个发送的数据内核会重传,发送缓存区数据一直增加
设置的发送超时只要发送缓存区能装的下,send就不会报错的(记住send只是拷贝数据到内核)
如何检测另一个端死了,必须采用以下方法
1.开启KEEP_ALIVE 心跳机制
2.应用层心跳机制
三:服务器主机崩溃后重启
之前TCP连接信息已丢失,对后续接收到的客户端以RST响应;
当然也可能在重启前就已经通过心跳机制检测到了异常
附非正常结束和正常结束及TCP状态切换图