Broken pipe异常分析报
1.错误描述
ClientAbortException: java.io.IOException: Broken pipe
可能出现原因:
TCP服务端write数据时,收到SIGPIPE信号(连接已经终止)
场景:
- TCP握手尚未结束时,连接已经close;
- 服务端收到一次read,但write了多次;
- 连接通道被占满,新连接被拒绝时,client中断了所有连接。
2.1.2分析
(1)在第一次连接已经正常握手,并正常close后,server端在此执行write操作。即对一个对端已经关闭的socket调用两次write,报出SIGPIPE信号,导致异常。
(2)请求接口本身问题或并发调用问题,引起了连接close或连接过多超限导致client端close连接。
问题原因
client端用户在杀死进程时,接口的TCP请求尚未完成(未完成的原因是处理时间长)。
导致server端write数据时,收到SIGPIPE信号,抛出Broken pipe异常。
但由于已经杀死了进程,并不会对用户产生任何影响。