?最近项目上出现了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
proxy_buffer_size 1024k;
proxy_buffers 16 1024k;
proxy_busy_buffers_size 2048k;
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、延长客户端超时时间,当然,不能太牺牲客户的体验
当然,问题都是千奇百怪的,每个人遇到的可能不同,所以,即供参考。。。
|