今天公司因为项目需求使用到了Java 客户端的websocket, 在本地环境和测试环境监听websocket是正常状态,上线之后访问异常,经过排查有以下两个问题:
1.线上nginx 的location =/ws设置了代理读取时间, proxy_read_timeout 600s; 如果这个时间以内客户端没有发消息给服务端,nginx会把websocket断开, 解决方案是 在客户端定时发送ping命令到服务端
static OkHttpClient mClient = new OkHttpClient.Builder()
.readTimeout(10, TimeUnit.SECONDS)//设置读取超时时间
.writeTimeout(10, TimeUnit.SECONDS)//设置写的超时时间
.connectTimeout(10, TimeUnit.SECONDS)//设置连接超时时间
.pingInterval(10,TimeUnit.SECONDS) //设置定时发送ping保持连接命令
.build();