Broken pipe异常分析及解决

Broken pipe异常分析报

1.错误描述

ClientAbortException: java.io.IOException: Broken pipe

可能出现原因:

TCP服务端write数据时,收到SIGPIPE信号(连接已经终止)

场景:

  1. TCP握手尚未结束时,连接已经close;
  2. 服务端收到一次read,但write了多次;
  3. 连接通道被占满,新连接被拒绝时,client中断了所有连接。

2.1.2分析

(1)在第一次连接已经正常握手,并正常close后,server端在此执行write操作。即对一个对端已经关闭的socket调用两次write,报出SIGPIPE信号,导致异常。

(2)请求接口本身问题或并发调用问题,引起了连接close或连接过多超限导致client端close连接。

问题原因

client端用户在杀死进程时,接口的TCP请求尚未完成(未完成的原因是处理时间长)。 
导致server端write数据时,收到SIGPIPE信号,抛出Broken pipe异常。 
但由于已经杀死了进程,并不会对用户产生任何影响。

posted @ 2024-07-15 22:57  KLAPT  阅读(6)  评论(0编辑  收藏  举报