位置: IT常识 - 正文

Broken Pipe问题及其解决(broken pipe write failed)

编辑:rootadmin
Broken Pipe问题及其解决 2022-06-27 10:01:17.501 ERROR 1 --- [nio-5010-exec-7] o.a.c.c.C.[.[.[/].[dispatcherServlet] : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is com.alibaba.excel.exception.ExcelGenerateException: Can not close IO.] with root causejava.io.IOException: Broken pipe at java.base/sun.nio.ch.FileDispatcherImpl.write0(Native Method) ~[na:na] at java.base/sun.nio.ch.SocketDispatcher.write(SocketDispatcher.java:62) ~[na:na] at java.base/sun.nio.ch.IOUtil.writeFromNativeBuffer(IOUtil.java:113) ~[na:na] at java.base/sun.nio.ch.IOUtil.write(IOUtil.java:79) ~[na:na] at java.base/sun.nio.ch.IOUtil.write(IOUtil.java:50) ~[na:na] at java.base/sun.nio.ch.SocketChannelImpl.write(SocketChannelImpl.java:532) ~[na:na] at org.apache.tomcat.util.net.NioChannel.write(NioChannel.java:135) ~[tomcat-embed-core-9.0.54.jar:9.0.54] at org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper.doWrite(NioEndpoint.java:1363) ~[tomcat-embed-core-9.0.54.jar:9.0.54] at org.apache.tomcat.util.net.SocketWrapperBase.doWrite(SocketWrapperBase.java:766) ~[tomcat-embed-core-9.0.54.jar:9.0.54] at org.apache.tomcat.util.net.SocketWrapperBase.writeBlocking(SocketWrapperBase.java:586) ~[tomcat-embed-core-9.0.54.jar:9.0.54] at org.apache.tomcat.util.net.SocketWrapperBase.write(SocketWrapperBase.java:530) ~[tomcat-embed-core-9.0.54.jar:9.0.54] at org.apache.coyote.http11.Http11OutputBuffer$SocketOutputBuffer.doWrite(Http11OutputBuffer.java:547) ~[tomcat-embed-core-9.0.54.jar:9.0.54] at org.apache.coyote.http11.filters.ChunkedOutputFilter.doWrite(ChunkedOutputFilter.java:110) ~[tomcat-embed-core-9.0.54.jar:9.0.54] at org.apache.coyote.http11.Http11OutputBuffer.doWrite(Http11OutputBuffer.java:194) ~[tomcat-embed-core-9.0.54.jar:9.0.54] at org.apache.coyote.Response.doWrite(Response.java:615) ~[tomcat-embed-core-9.0.54.jar:9.0.54] at org.apache.catalina.connector.OutputBuffer.realWriteBytes(OutputBuffer.java:340) ~[tomcat-embed-core-9.0.54.到底什么是断管?

推荐整理分享Broken Pipe问题及其解决(broken pipe write failed),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:broken pipe怎么解决,broken pipe异常分析及解决,brokenpipeerror broken pipe,broken pipe from,broken pipe or closed connection,brokenpipeerror broken pipe,broken pipe异常分析及解决,brokenpipeerror broken pipe,内容如对您有帮助,希望把文章链接给更多的朋友!

简单来说,Broken Pipe 意味着一台机器正在尝试从管道读取数据或向管道写入数据,而管道另一端的机器已经死亡或终止。现在,由于连接已关闭,应建立新连接以进一步传输数据,否则数据传输将停止。

它是如何发生的?

此问题的最常见原因之一是客户端在执行任何操作(如加载页面或下载附件)时关闭打开的连接。当使用 Nginx 之类的代理/负载均衡器(例如关闭 Web 浏览器甚至简单地取消下载)或连接速度很慢时,强制关闭某些连接也会发生这种情况。

一个简单的场景:浏览器向服务器请求资源,作为响应,服务器向浏览器返回响应。如果在服务器向浏览器发送响应时用户关闭了浏览器怎么办?服务器与浏览器之间的连接意外关闭。然后这会导致 Broken Pipe,该异常被称为 java.io.IOException: Broken Pipe in Java。

这也可能发生在任何中断客户端和服务器之间连接的事情上,包括性能问题甚至网络间歇性问题。

并非每个 Broken Pipe 异常都是开发人员的错

导致此异常的可能因素:最终用户数量

由于Broken Pipe的主要原因之一是用户的行为(在服务器完成发送响应之前意外关闭活动浏览器会话),最终用户数量的增加增加了Broken Pipe的机会。

重响应负载

来自服务器的重响应需要大量时间才能传输到客户端,而这个巨大的时间跨度可能是 Broken Pipe 的情况。

服务器超时

如果 Web 服务器在等于服务器设置的超时值的特定时间内无法得到服务的响应,它会关闭与客户端的连接,返回 503: Gateway Timeout 并因此导致 Broken Pipe。

断管异常是危险信号吗?

公平地说,这不是一个危险信号,因为它很大程度上是由用户的正常行为引起的,并且总是有可能由于某些故障而关闭服务。但是,如果服务器一次运行在相对大量的用户请求上,那么不仅是 Broken Pipe,而且任何异常似乎都会造成问题。

在我的例子中,由于高网络流量,日志被损坏的管道异常淹没。因为,写入文件(I/O 操作)是服务器执行的昂贵操作之一,想象一下服务器被与 Broken Pipe 相关的异常淹没,并且服务器必须投入大量资源才能将该异常堆栈跟踪写入日志文件。这导致服务器响应缓慢并使其迟缓。

在这一点上,我意识到,当扩展到大流量时,YES BROKEN PIPE EXCEPTION 是一个红色信号。

处理或移除破损管道的挑战 该系统使用 Wildfly 10.1 作为应用程序服务器,并在 JavaEE 7 上编写。处理这种情况对我来说不是小菜一碟,因为:

在本地或 QA 环境中复制此异常需要正确对齐所有行星(开个玩笑),但是是的,这太难了。

在 Java 中处理异常很容易,只要在 catch 块中捕获异常即可。未处理异常的性质:java.io.IOException: Broken pipe 是这样的,它从 Wildfly 容器中引发并在堆栈跟踪中注销,而不是被困在 catch 块中。现在,想象一下必须处理无法从代码中捕获的异常。天哪!!!!

Broken Pipe问题及其解决(broken pipe write failed)

您永远不会知道,哪个请求引发了问题,因为服务器收到大量请求,其中任何一个都可能是异常的原因。将日志与套接字端点一起添加到每个 REST 端点是不可行的。

修复 java.io.IOException : Broken Pipe 最后,经过这么多断章取义的谈话,这里是主要部分(希望它值得等待)。

从系统中删除异常的两种方法是:

调查异常的根本原因,并消除它。 使用适当的日志记录或某些操作来优雅地处理异常。 消除根本原因 要求用户不要意外关闭连接 这是不可能的,看在上帝的份上

减少 api 响应负载

这在某种程度上是可以实现的,但是在遗留系统中,对大量数据进行操作,重写所有逻辑以使 api 响应不重也不在所有情况下都是可行的。

增加服务器超时

Nginx 有一个名为proxy_read_timeout的变量,它的默认值为 60s,增加这个值也会最大限度地减少 Broken Pipe 的机会。

即使在消除了在这种情况下本身很难检测到的确切根本原因之后,我们也不能完全排除断管的存在。我们可以吗?

因此,下一个解决方案是优雅地处理 Broken Pipe。

处理 java.io.IOException: Broken Pipe

抑制来自 logger 本身的日志 如果您使用 log4j 作为日志管理器,将以下配置添加到 log4j.properties 将有助于摆脱由于 Broken Pipe 导致的异常泛滥日志。

log4j.logger.org.apache.catalina.connector.ClientAbortException = ERROR, console, cloudAppenderlog4j.additivity.org.apache.catalina.connector.ClientAbortException = false

在 Wildfly 中升级 Resteasy 我们使用 JAX-RS 的 Resteasy 实现在 Java 中实现 REST,Resteasy v3.0.19 与 Wildfly 10.1 捆绑在一起。希望能在 resteasy 本身中找到一些修复,我开始深入研究 Resteasy 的发行说明,发现在 Resteasy-Client v3.1.1 之后,可以从代码中捕获 Unhandled Exception: java.io.IOException,不像容器暴露它直接进入logtrace。因此,Resteasy Client 的升级版本允许我们通过 Global Exception Handler 来处理异常(后面会介绍)。 在 Wildfly 中升级 Resteasy 的步骤

查找 Resteasy 分发 jar

的位置: Resteasy 分发 jar 的位置位于: WILDFLY_HOME/modules/system/layers/base/org/jboss/resteasy/resteasy-jaxrs/main 文件名:resteasy-jaxrs-3.0.19 .Final.jar

从Resteasy 下载处下载resteasy 目标版本(3.1.1 及以上)的 zip 文件

在临时目录中解压文件。它里面还有另外两个 zip 文件: resteasy-jboss-modules-3.1.1.Final-mavenized.zip和 resteasy-jboss-modules-3.1.1.Final.zip

在以下位置解压缩两个 .zip 文件: WILDFLY_HOME/modules/system/layers/base

在pom.xml中更新 resteasy 依赖项的版本

<dependency> <groupId>org.jboss.resteasy</groupId> <artifactId>resteasy-jaxrs</artifactId> <version>3.1.1.Final</version> <scope>provided</scope></dependency>

使用 Global Exception Handler 我进一步从 java 代码本身添加了 Generic Exception Mapper,以捕获和处理 Broken Pipe。 我的最终方法 虽然我已经收集了多种技术来解决这个问题,但以下是我实际实现的东西:

将 Wildfly 升级到 v11.0,因为它自动附带了 Resteasy v3.1.1(我真正想要的版本)捆绑在其中。 通过 Global Exception Handler 处理异常 有了这个,Broken Pipe 的问题现在只存在于旧的日志档案中.

参考文献:https://dev.to/bishwapoudel/how-i-fixed-java-io-ioexception-broken-pipe-in-java-wildfly-10-1-86k

本文链接地址:https://www.jiuchutong.com/zhishi/287116.html 转载请保留说明!

上一篇:最奢华的iPhone 4S是什么(最奢华的女士腕表)

下一篇:网站国际化 多语言处理工具i18n安装使用方法(网站国际化方案)

  • iphone13pro支持快充吗(13pro有快充吗)

    iphone13pro支持快充吗(13pro有快充吗)

  • 腾讯会议私聊主持人看得到吗(腾讯会议私聊主持人视角)

    腾讯会议私聊主持人看得到吗(腾讯会议私聊主持人视角)

  • 苹果手机微信接收的文件在哪里找(苹果手机微信接视频需要开锁)

    苹果手机微信接收的文件在哪里找(苹果手机微信接视频需要开锁)

  • 360浏览器怎么无痕浏览(360浏览器怎么无痕迹浏览)

    360浏览器怎么无痕浏览(360浏览器怎么无痕迹浏览)

  • 苹果删照片怎么全选(苹果删照片怎么全部删除)

    苹果删照片怎么全选(苹果删照片怎么全部删除)

  • 苹果7网络不稳定怎么办(苹果网络不稳定怎么回事)

    苹果7网络不稳定怎么办(苹果网络不稳定怎么回事)

  • 微信图片怎么保存到电脑文件夹(微信图片怎么保存成表情)

    微信图片怎么保存到电脑文件夹(微信图片怎么保存成表情)

  • 苹果se2单卡还是双卡(苹果se2 单卡)

    苹果se2单卡还是双卡(苹果se2 单卡)

  • 电脑word怎么复制图片文字(电脑word怎么复制页面)

    电脑word怎么复制图片文字(电脑word怎么复制页面)

  • pot al10是华为什么型号(华为pot—al10多少钱)

    pot al10是华为什么型号(华为pot—al10多少钱)

  • ai出血什么意思(ai 出血)

    ai出血什么意思(ai 出血)

  • iphone8无线充电功率(iPhone8无线充电速度)

    iphone8无线充电功率(iPhone8无线充电速度)

  • 手机上部分发热怎么办(手机上部分发热散热器又贴不到上部分)

    手机上部分发热怎么办(手机上部分发热散热器又贴不到上部分)

  • 手机按住说话怎么不能用了(手机按住说话怎么不出现字)

    手机按住说话怎么不能用了(手机按住说话怎么不出现字)

  • 剪映9:16比例为什么还是原屏呢(剪映里比例原则9比16后不是横视频)

    剪映9:16比例为什么还是原屏呢(剪映里比例原则9比16后不是横视频)

  • 128kbs网速能看视频吗(128k网速能看视频吗)

    128kbs网速能看视频吗(128k网速能看视频吗)

  • 清理微信缓存聊天记录图片还在吗(清理微信缓存聊天记录视频还在吗)

    清理微信缓存聊天记录图片还在吗(清理微信缓存聊天记录视频还在吗)

  • wpsoffice怎么搜索关键词(wpsoffice怎么搜索表格里的内容)

    wpsoffice怎么搜索关键词(wpsoffice怎么搜索表格里的内容)

  • vivo手机设置sos在哪里(vivo手机设置搜索)

    vivo手机设置sos在哪里(vivo手机设置搜索)

  • 小米盒子如何升级系统(小米盒子如何升级固件)

    小米盒子如何升级系统(小米盒子如何升级固件)

  • 打印机如何调缩印(打印机怎样设置缩放)

    打印机如何调缩印(打印机怎样设置缩放)

  • vivo x20plus防水吗(vivox21手机防水性能好吗)

    vivo x20plus防水吗(vivox21手机防水性能好吗)

  • eleal00是什么型号(elzan00是什么型号)

    eleal00是什么型号(elzan00是什么型号)

  • 抖音左右镜像怎拍摄教(抖音左右镜像怎么调整)

    抖音左右镜像怎拍摄教(抖音左右镜像怎么调整)

  • 投屏怎么快进(三星电视投屏怎么快进)

    投屏怎么快进(三星电视投屏怎么快进)

  • outlook中国选哪个时区(outlook国内能用吗)

    outlook中国选哪个时区(outlook国内能用吗)

  • 红米k20pro多少克(红米k20pro多少千克)

    红米k20pro多少克(红米k20pro多少千克)

  • 华为畅享9e和9的区别(华为畅享9e和9的对比)

    华为畅享9e和9的区别(华为畅享9e和9的对比)

  • 魅蓝s6值得入手吗(魅蓝s62021)

    魅蓝s6值得入手吗(魅蓝s62021)

  • Linux系统Centos没有网卡eth0配置文件的解决方法(centos只有lo)

    Linux系统Centos没有网卡eth0配置文件的解决方法(centos只有lo)

  • 【华为OD机试真题】1115 - 查找单入口空闲区域(JAVA C++ Python JS) | 机试题+算法思路+考点+代码分析(华为od机试成绩什么时候出来)

    【华为OD机试真题】1115 - 查找单入口空闲区域(JAVA C++ Python JS) | 机试题+算法思路+考点+代码分析(华为od机试成绩什么时候出来)

  • vue面试题整理(2022-持续更新中...)(vue面试题2020)

    vue面试题整理(2022-持续更新中...)(vue面试题2020)

  • 消费税应该怎么缴纳
  • 本月发生费用下月收到发票
  • 邮寄文件快递费账务处理
  • 原材料盘亏自然损耗
  • 企业所得税不超过300万怎么算
  • 未达起征点的税金如何做账
  • 发票遗失如何报销
  • 股东股权比例怎么分配
  • 代理记账公司收费项目
  • 建设工程的停工损失包括哪些内容
  • 装饰设计费计入什么科目
  • 税收分类编码怎么导出来
  • 金税盘可以异地使用吗
  • 国税电子钥匙常见问题解答
  • 如何计算房地产容积率与土地面积
  • 个人转让上市公司股票交增值税吗
  • 电器供应
  • 生产设备软件服务有哪些
  • 知道发票代码怎么查询发票号码
  • 多交的增值税可以抵所得税吗?
  • 美团收入怎么处理的?
  • 销售折让和折扣的风险点
  • 出售使用过的车辆如何交印花税呢
  • 在win7中,如何将所有窗口进行层叠排列显示
  • php7 ??
  • yolov8训练自己的数据
  • 像指纹一样的图形
  • 怎么算土地增值税
  • 应收账款的账期是什么意思
  • tf club下载
  • 前期认证相符
  • 物流公司修理班的管理有那些书
  • 转增资本属于什么会计科目
  • 数量金额式账页图片
  • 当月销售次月开票就按次月申报
  • photoshop虚化局部
  • 商品流通企业采用售价法核算条件下
  • react高阶组件
  • 科目余额表怎么填
  • 企业的净利润率
  • 往来款项的含义
  • 什么是企业会计确认计量和报告的空间范围
  • 小微企业所得税税率多少
  • 固定资产账务处理候文江视频
  • 政府补助的分类包括
  • 购买现金支票的申请说明
  • 计提税费和实际缴纳的有差额怎么办
  • 补助资金如何做账
  • 贴现利息高好还是低好
  • 直接减免增值税计入其他收益
  • 本月取得的发票入账后次月对方能红冲吗
  • 其他应收款如何做坏账处理
  • 年报上的从业人数是什么意思
  • 营改增后建筑行业增值税税率
  • 影响折旧的因素有哪三个方面
  • 2020年工伤赔偿标准表
  • 企业的固定资产由于技术进步等原因
  • 什么是盈余公积和资本公积的区别
  • sql2008没有数据库
  • win8系统如何查看电脑型号
  • 如何查看windows2008修改密码日志
  • fedora os
  • win7系统安装软件闪退
  • 计算机 win10 桌面
  • mac系统字体大小设置
  • mac锁定快捷键
  • qclean.exe - qclean是什么进程 有什么用
  • win7移动硬盘无法弹出
  • /usr/bin/install: 无法创建一般文件‘/usr/local/man/man1/cjpeg.1’: 没有那个文件
  • unity反射效果
  • 相机调取失败
  • unity 面向对象
  • jquery异步提交表单
  • python中django
  • jQuery添加类名
  • js判断手机访问还是电脑访问
  • 个人所得税子女教育到多大结束
  • 天河地税局局长简介
  • 个人开个什么公司比较好
  • 微信 税务
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设