首页 > 其他 > 详细

关于socket通信时SIGPIPE的问题

时间:2014-03-01 05:28:15      阅读:444      评论:0      收藏:0      [点我收藏+]

一,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的问题,布布扣,bubuko.com

关于socket通信时SIGPIPE的问题

原文:http://blog.csdn.net/lv_xinmy/article/details/20138543

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!