记一次netty-socketio1.7.7升级到netty-socketio1.7.15导致客户端无法连接服务器

升级netty-socketio从1.7.7到1.7.15后,客户端无法连接服务器,报错‘An exceptionCaught() event was fired...’。分析源码发现协议升级超时,客户端使用polling无法完成websocket升级。解决方案是明确指定连接协议为websocket,避免使用默认的polling,从而解决连接问题。
摘要由CSDN通过智能技术生成

    由于1.7.7已经是几年前发布的版本了所以最近升级了一下游戏服务端netty-socketio的版本,但是发现客户端一直都无法连接上服务端,并且报错:An exceptionCaught() event was fired, and it reached at the tail of the pipeline. It usually means the last handler in the pipeline did not handle the exception.

打印了一下DEBUG日志


    发现在协议升级时出现错误导致无法升级,通过分析源码得知upgrade的时间已经过了预设值的5秒超时时间,通过程序设置的定时任务清除了client所以会导致在执行handler时抛出错误,又看了一下客户端的network如下所示:


    可以看到transport=polling,并且握手成功了,升级协议时一直在pending无法升级成功,所以会导致错误,客户端连接的代码如下(我是通过官网的demo进行连接的 坑呀!!)

    当没有指定传输协议时,默认的是使用polling轮询进行连接,所以指定一下链接协议,直接使用websocket进行连接,连接成功。


    由于这个坑很少人踩到,网上的资料很少,找错误的方向一直没对,倒腾了很久,所以记录一下,节约下大家的时间。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值