最近项目上出现了java.io.IOException: Broken pipe问题,后边,又出现了org.apache.catalina.connector.ClientAbortException: java.io.IOException: Connection reset by peer问题,其实,找到原因后,都是一个问题引起的。

错误信息

前端

浏览器/小程序接口返回报错信息:

net::ERR_INCOMPLETE_CHUNKED_ENCODING 200 (OK)

后端

 出现问题后,先看了下日志,第一眼看到的事:

  java.io.IOException: Broken pipe报错,然后,分析了下,大概的意思是,前端调用然后因为某种原因,和后端服务器断开了。但是,从看到的结果,可能不是直接报错原因。

  然后,自己尝试用wifi调用,有的时候可以,有时报错,用手机4G试了了,一直报错,所以,怀疑是因为数据量大导致的断开,然后看了下日志,报错:org.apache.catalina.connector.ClientAbortException: java.io.IOException: Connection reset by peer。

原因

怀疑就是数据量大,导致的前后端通讯断开,所以,怀疑是nginx配置的有问题,所以配置下nginx转发的限制。

解决:

修改nginx的配置文件 nginx.config

#设置代理服务器(nginx)保存用户头信息的缓冲区大小

proxy_buffer_size 1024k;

#proxy_buffers缓冲区,网页平均在32k以下的设置

proxy_buffers 16 1024k;

#高负荷下缓冲大小(proxy_buffers*2)

proxy_busy_buffers_size 2048k;

#设定缓存文件夹大小,大于这个值,将从upstream服务器传

proxy_temp_file_write_size 2048k;

1.

2.

3.

4.

5.

6.

7.

8.

重启nginx

nginx -t

nginx -s reload

1.

2.

解决了。

java.io.IOException: Broken pipe学习

 既然,我已经查问题到这了,那就研究下Broken pipe

认识

pipe是管道的意思,管道里面是数据流,通常是从文件或网络套接字读取的数据。

当该管道从另一端突然关闭时,会发生数据突然中断,即是broken。

对于文件File来说,这可能是文件安装在已断开连接的光盘或远程网络上。

对于socket来说,可能是网络被拔出或另一端的进程崩溃。

在Java中,没有具体的BrokenPipeException。

将此类错误包含在另一个异常,例如java.io.IOException:Broken pipe

分析和解决

分析

1、客户端请求服务器数据,服务器突然挂了;

2、客户端请求服务端数据,服务端正常返回,凡是客户端由于超时等原因断开。

当然,通过上边的分析,我系统出现的问题,是服务器返回异常了,nginx端因为数据量超限制,关闭了通信连接,导致的前端报错。

压测

如果,不是显而易见的情况,需要,我们自己压测下,看下问题究竟出在哪里了

是DB连接数,通讯问题,程序问题,还是其他中间件使用问题。

解决

可能存在的解决方式

服务端:

1、查看是否有负载或者代理,是否因为中间件的问题,例如:nginx

2、是否因为程序导致的时间过长,这中情况,原因有可能很多了

 数据库连接数,RPC通讯,HTTP通讯等,看看修改一些连接数或者连接时长

客户端:

1、延长客户端超时时间,当然,不能太牺牲客户的体验