Netty socket 客户端 如何正确重新连接服务端 接收数据推送

徘徊边缘 提交于 2021-01-13 18:58:02

当服务端断开连接时 需要客户端进行重新连接

 


 

错误写法:

 


以上写法 根据全局成员非静态变量connectStatus判断 是否建立连接时。读取不到更新后的值。

当修改connectStatus 为全局静态变量时 可以读取到最新的值,但是会导致不能及时的将线程池中的任务 取消掉 会对服务端进行多次连接。从而服务端 推送过来的数据 不能接收到。

 


关于重连注意点:

ChannelFuture future = client.connect(socketIp, port);future.awaitUninterruptibly();

初始化连接使用这个

Future.awaitUninterruptibly

当再 channelInactive  进行异步定时重连时  不能加await()  会导致程序阻塞。

上述代码导致的问题:

 



 

遇到得奇葩问题:

 


当标红方法 不是静态方法,时普通成员方法 这个定时任务不会执行。

 

最优写法:

采用schedule 延迟执行,监听返回结果 如果没有连接成功 则进行递归操作;否则停止任务。



本文分享自微信公众号 - 纯洁的明依(chenmingyi20181223)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!