最近项目上出现了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、延长客户端超时时间,当然,不能太牺牲客户的体验
标签:java,nginx,pipe,Broken,报错,io,Java From: https://blog.51cto.com/u_16265692/11937301