netty 客户端重连接,用定时器不能实现重连,怎么办

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了netty 客户端重连接,用定时器不能实现重连,怎么办相关的知识,希望对你有一定的参考价值。

参考技术A 这个要分情况了。 如果是UDP的话,就不存在连接不连接的问题了。因为这个是面向无连接的,直接发送数据即可。 如果是TCP的话,就需要连接了。你应该这么办: 首先每隔一段时间查看是否与服务器断开了,或者根据你具体的要求来查看是否断开。 第...

即时通讯开发Netty实现心跳机制断线重连机制

做IM或推送系统需要面临很多问题,比如:资料少(众所周之的某互联网巨头几乎不分离这方面的资料)、轮子少(Netty这种牛逼的框架出现的有点晚)、难度高(高并发怎么实现?C10K问题呢?)。

 

为何需要心跳机制?

所谓心跳, 即在 TCP 长连接中, 客户端和服务器之间定期发送的一种特殊的数据包, 通知对方自己还在线, 以确保 TCP 连接的有效性。

注:心跳包还有另一个作用,经常被忽略,即:一个连接如果长时间不用,防火墙或者路由器就会断开该连接(PS:术语叫“端口老化”)。

先理解一下核心Handler:IdleStateHandler

在 Netty 中, 实现心跳机制的关键是 IdleStateHandler, 那么这个 Handler 如何使用呢?

先看下它的构造器:
    
public IdleStateHandler(int readerIdleTimeSeconds, int writerIdleTimeSeconds, int allIdleTimeSeconds)
    this((long)readerIdleTimeSeconds, (long)writerIdleTimeSeconds, (long)allIdleTimeSeconds, TimeUnit.SECONDS);

这里解释下三个参数的含义:

    readerIdleTimeSeconds: 读超时. 即当在指定的时间间隔内没有从 Channel 读取到数据时, 会触发一个 READER_IDLE 的 IdleStateEvent 事件.
    writerIdleTimeSeconds: 写超时. 即当在指定的时间间隔内没有数据写入到 Channel 时, 会触发一个 WRITER_IDLE 的 IdleStateEvent 事件.
    allIdleTimeSeconds: 读/写超时. 即当在指定的时间间隔内没有读或写操作时, 会触发一个 ALL_IDLE 的 IdleStateEvent 事件.


注:这三个参数默认的时间单位是秒。若需要指定其他时间单位,可以使用另一个构造方法:IdleStateHandler(boolean observeOutput, long readerIdleTime, long writerIdleTime, long allIdleTime, TimeUnit unit)即时通讯聊天软件app开发可以加蔚可云的v:weikeyun24咨询

 

使用IdleStateHandler实现心跳(客户端篇)

下面将使用IdleStateHandler来实现心跳,Client端连接到Server端后,会循环执行一个任务:随机等待几秒,然后ping一下Server端,即发送一个心跳包。

当等待的时间超过规定时间,将会发送失败,以为Server端在此之前已经主动断开连接了。

如何用Netty实现网络断线重连机制?

断线重连对于复杂网络非常有用(没有这个,一旦断网,通信就无法自动恢复了),这里就不过多介绍,相信各位都知道是怎么回事。这里只说大致思路,然后直接上代码。

实现思路

客户端在监测到与服务器端的连接断开后,或者一开始就无法连接的情况下,使用指定的重连策略进行重连操作,直到重新建立连接或重试次数耗尽。

对于如何监测连接是否断开,则是通过重写ChannelInboundHandler#channelInactive来实现,但连接不可用,该方法会被触发,所以只需要在该方法做好重连工作即可。

以上是关于netty 客户端重连接,用定时器不能实现重连,怎么办的主要内容,如果未能解决你的问题,请参考以下文章

Netty 断线重连解决方案

用netty实现客户端断线重连

Netty 如何实现心跳机制与断线重连?

Netty 实现心跳机制与断线重连

netty的断线重连问题

开发im即时通讯如何用Netty实现心跳机制断线重连机制