回射程序中的异常分析
前言
在之前的文章中,我对回射程序做了分析,但那一次的分析是基于正常执行的。本文将说明在各种异常情况下该程序的执行情况。
异常一 accept返回前连接终止
描述:客户端在3次握手刚好完成的时候,发出RST。参见下图:
影响:服务器端的accept函数将会返回-1,同时errno的值被置为ECONNABORTED。
异常二 服务器子进程终止
描述:服务器子进程被终止( 如kill命令 )
过程分析( 服务器子进程被终止后 ):
1. 服务器向客户发送FIN 客户回应ACK
2. SIGCHLD信号被发送给服务器并得到正确处理
3. 此时,客户并没有发生任何特殊的事情!!它若无其事的阻塞在Fgets函数上。
4. 当客户此时向终端输入字符并回车,因为服务器已经终止了对这位客户的服务,因此会“无情”地返回一个RST。
5. 客户此后调用Readline函数,但它Read到了1中的那个FIN,于是异常终止。
应对方法:客户应该同时阻塞于分节和IO输入,需要用到IO复用技术。此乃后话。
异常三 SIGPIPE 信号
描述:客户向已经对其发送RST信号的服务器写入
影响:内核将会向进程发送SIGPIPE信号,此信号默认处理时关闭此进程。
异常四 服务器崩溃( 在客户端主动连接之前 )
描述:服务器突然断网了或者断电了
影响:如此第一次SYN分节都不会被送达给服务器,故Readline将等待一定时间后返回错误,errno被置为EHOSTUNREACH或者ENETUNREACH。