关于socket通信时SIGPIPE的问题

一,SIGPIPE信号的产生

在Linux平台下,写socket的程序时,难免总是会碰到SIGPIPE 的问题,此时如果不作处理,那你可能需要一个监控,每1分钟检查进程是否存在,不存在的话,就重新启动,因为进程对SIGPIPE的默认响应是退出,这肯定不是你想要的最终方案。

SIGPIPE 的产生是由于往一个断开的连接上写数据,该连接已经被复位,这就会引起操作系统抛出一个SIGPIPE信号给相应的进程,而相应的进程在收到操作系统这个信号时,就退出,这是缺省的处理方式。


二,屏蔽信号

我们当然不希望应用退出,此时就要进程把这个信号给屏蔽掉,这一般是可行的,如下:

    struct sigaction action;
    action.sa_handler = SIG_IGN;
    sigaction( SIGPIPE, &action, 0 );

或者简单的

signal(SIGPIPE,SIG_IGN);

在大部分时候都是可行的,系统可以屏蔽这个错误,并且给write返回-1,表示写错了。


三,多线程的时候

但在多线程的时候,你可能在主线程里面屏蔽了这个信号,此时在其它的线程中是无效的,其它的线程在收到SIGPIPE信号时,该退出还是要退出。这是因为线程创建的时候,没有默认从主线程那里继承屏蔽操作,可能需要手动操作。

sigset_t signal_mask;
sigemptyset (&signal_mask);
sigaddset (&signal_mask, SIGPIPE);


你可能感兴趣的:(关于socket通信时SIGPIPE的问题)