问题:
最近写了一个网络通讯程序,在局域网内调试测试都没有出问题,但是一拿到真实环境就总是出错,异常自动退出
最后根据strace发现,是因为sigpipe信号给结束掉的。
关于sigpipe信号:
产生原因:
当服务器close一个连接时,若client端接着发数据。根据TCP协议的规定,会收到一个RST响应,client再往这个服务器发送数据时,系统会发出一个SIGPIPE信号给进程,告诉进程这个连接已经断开了,不要再写了。
信号默认处理:
根据信号的默认处理规则SIGPIPE信号的默认执行动作是terminate(终止、退出),所以client会退出。若不想客户端退出可以把SIGPIPE设为SIG_IGN。
解决方式:
程序中加signal(SIGPIPE,SIG_IGN);把这个信号扔给系统处理。
为了防止僵尸进程,可以把子程序通过设置signal(SIGCHLD,SIG_IGN);来交给系统init来回收。
温馨提示:
所以大家在开发网络通讯程序的时候一定要注意这个信号的处理。切记