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 @   KLAPT  阅读(2290)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
历史上的今天:
2021-07-15 MyBatis 流式查询
2019-07-15 线程 多线程 并发 并行
点击右上角即可分享
微信分享提示