(gdb) bt
#0 0x00110416 in __kernel_vsyscall ()
#1 0x0092f918 in send () from /lib/libpthread.so.0
这是因为在调用socket发送函数send()时,出现的异常错误,可能的原因是因为tcp连接可能不正常,导致了send()数据失败,系统会收到SIGPIPE信号,
系统默认的处理是退出进程。可以让系统屏蔽SIGPIPE信号,这样服务端进程就不会异常退出了,可以继续运行。
1.在main函数一开始执行下面的屏蔽SIGPIPE信号:
signal(SIGPIPE, SIG_IGN);
2. 但在线程中还是会出现SIGPIPE问题,添加下面的代码,屏蔽线程中的SIGPIPE信号:
sigset_t signal_mask;
sigemptyset (&signal_mask);
sigaddset (&signal_mask, SIGPIPE);
int rc = pthread_sigmask (SIG_BLOCK, &signal_mask, NULL);
if (rc != 0)
{
printf("block sigpipe error\n");
}
上面的代码应写在main函数的开头,创建线程之前。
问题解决。
转自:http://blog.youkuaiyun.com/doctorllm/article/details/43410027
最近为测试自己写的服务器,临时写了一个客户端,总是发现客户端收到SIGPIPE的信号,然后进程退出。
为了客户端进程收到SIGPIPE不退出,我打算忽略该信号,下面是我用过的方法:
(1)间接忽略
(2)直接忽略
(3)重载signaction
(1)(2)(3)都不能够忽略,客户端收到SIGPIPE之后依然进程退出。
于是乎,查SIGPIPE这个信号的特性:
如果在写到管道时读进程已终止,则产生此信号。当类型为SOCK_STREAM的套接字已不再连接时,进程写到该套接字也产生此信号。
——《UNIX环境高级编程》中10.2节
由于我的客户端是用send()进行发送数据的,通过man手册查看send()函数,看到有一条这样说:
MSG_NOSIGNAL
Requests not to send SIGPIPE on errors on stream oriented sockets when the other end breaks the connection. The EPIPE error is still returned.
于是将send()最后一个参数flags改为MSG_NOSIGNAL,再次启动客户端测试。SIGPIPE被忽略,客户端没有因为该信号退出。
转自: http://blog.youkuaiyun.com/woxiaozhi/article/details/40624033