关于Websocket一次Broken pipe的异常处理

最近公司开发的一个项目,使用了Websocket。在测试环境是没有什么问题,可以正常使用。但是在部署到生产环境之后,调用websocket后。如果一分钟内没有进行交互则会自动断开,同时有异常信息“java.io.IOException: java.util.concurrent.ExecutionException: java.net.SocketException: Broken pipe”。针对这一问题,网上的回答各种各样。在网上找到一个类似的算是解决了问题。

1、系统环境:Tomcat 7 、jdk 7、nginx

2、系统返回异常“java.io.IOException: java.util.concurrent.ExecutionException: java.net.SocketException: Broken pipe

3、解决方法:在nginx对应的server下面把“proxy_read_timeout ” 的时间由60调整到600即可。


PS:

nginx比较强大,可以针对单个域名请求做出单个连接超时的配置. 

比如些动态解释和静态解释可以根据业务的需求配置

proxy_connect_timeout :后端服务器连接的超时时间_发起握手等候响应超时时间

proxy_read_timeout:连接成功后_等候后端服务器响应时间_其实已经进入后端的排队之中等候处理(也可以说是后端服务器处理请求的时间)

proxy_send_timeout :后端服务器数据回传时间_就是在规定时间之内后端服务器必须传完所有的数据

猜你喜欢

转载自blog.csdn.net/hanchao_h/article/details/78584225