服务器关闭已连接客户端socket,客户端继续write引起的问题

当服务器关闭TCP连接后,客户端继续尝试发送数据会导致SIGPIPE信号产生,系统默认会终止客户端进程。通过设置SIGPIPE信号为SIG_IGN可避免进程退出。Brokenpipe错误通常在write操作到已关闭的socket时出现,也会引发SIGPIPE信号。如果服务器使用fork,应处理SIGCHLD信号以防止僵尸进程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

服务端关闭已连接客户端socket,客户端接着发数据产生问题,
1. 当服务器close一个连接时,若client端接着发数据。根据TCP协议的规定,会收到一个RST响应,client再往这个服务器发送数据时,系统会发出一个SIGPIPE信号给进程,告诉进程这个连接已经断开了,不要再写了。
      根据信号的默认处理规则SIGPIPE信号的默认执行动作是terminate(终止、退出),所以client会退出。若不想客户端退出可以把SIGPIPE设为SIG_IGN
        如:      signal(SIGPIPE,SIG_IGN);
                   这时SIGPIPE交给了系统处理。
 
2. 客户端write一个已经被服务器端关闭的sock后,返回的错误信息Broken pipe.
          1)broken pipe的字面意思是“管道破裂”。broken pipe的原因是该管道的读端被关闭。
          2)broken pipe经常发生socket关闭之后(或者其他的描述符关闭之后)的write操作中
     3)发生broken pipe错误时,进程收到SIGPIPE信号,默认动作是进程终止。
          4)broken pipe最直接的意思是:写入端出现的时候,另一端却休息或退出了,
              因此造成没有及时取走管道中的数据,从而系统异常退出;
 
 
 
  服务器采用了fork的话,要收集垃圾进程,防止僵尸进程的产生,可以这样处理:
                  signal(SIGCHLD,SIG_IGN); 交给系统init去回收。
    这里子进程就不会产生僵尸进程了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值