最近项目上出现了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;

重启nginx

nginx -t
nginx -s reload

解决了。

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、延长客户端超时时间,当然,不能太牺牲客户的体验

当然,问题都是千奇百怪的,每个人遇到的可能不同,所以,即供参考。。。