signal(SIGPIPE, SIG_IGN)

当服务器关闭连接时,client端若继续发送数据,会收到SIGPIPE信号导致程序退出。通过`signal(SIGPIPE, SIG_IGN)`可以忽略此信号,避免程序因SIGPIPE信号而终止。测试不同处理SIGPIPE的方式,包括忽略信号、捕获信号和write过程中的处理,展示了处理SIGPIPE信号的重要性。" 114076223,10554129,Java Web应用中同名类加载问题与自定义ClassLoader,"['Java', '类加载器', 'Web开发', 'Tomcat']
摘要由CSDN通过智能技术生成

本文转自网络

关于SIGPIPE导致的程序退出

收集一些网上的资料,以便参考:

http://blog.chinaunix.net/u2/69143/showart_1087349.html

     当服务器close一个连接时,若client端接着发数据。根据TCP协议的规定,会收到一个RST响应,client再往这个服务器发送数据时,系统会发出一个SIGPIPE信号给进程,告诉进程这个连接已经断开了,不要再写了。
    根据信号的默认处理规则SIGPIPE信号的默认执行动作是terminate(终止、退出),所以client会退出。若不想客户端退出可以把SIGPIPE设为SIG_IGN

    如:    signal(SIGPIPE,SIG_IGN);
    这时SIGPIPE交给了系统处理。

  服务器采用了fork的话,要收集垃圾进程,防止僵尸进程的产生,可以这样处理:
  signal(SIGCHLD,SIG_IGN); 交给系统init去回收。
   这里子进程就不会产生僵尸进程了。


http://www.cublog.cn/u/31357/showart_242605.html


好久没做过C开发了,最近重操旧业。
听说另外一个项目组socket开发遇到问题,发送端和接受端数据大小不一致。建议他们采用writen的重发机制,以避免信号中断错误。采用后还是有问题。PM让我帮忙研究下。
UNP n年以前看过,很久没做过底层开发,手边也没有UNP vol1这本书,所以做了个测试程序,研究下实际可能发生的情况了。
 
测试环境:AS3和redhat 9(缺省没有nc)
 
先下载unp源码:
wget http://www.unpbook.com/unpv13e.tar.gz
tar xzvf *.tar.gz;
configure;make lib.
然后参考str_cli.c和tcpcli01.c,写了测试代码client.c
 
 

#include    "unp.h"

#defineMAXBUF 40960
voidprocessSignal(intsigno)
{
    printf("Signal is %d/n",signo);
    signal(signo,processSignal);
}
void
str_cli(FILE*fp,intsockfd)
{
    char    sendline[MAXBUF],recvline[MAXBUF];

    while(1){

        memset(sendline,'a',sizeof(sendline));
        printf("Begin send %d data/n",MAXBUF);
        Writen(sockfd,sendline<

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值