链接服务器包含的前缀超出了最大的限值_netty客户端长链接心跳检测重连机制...

本文介绍了Netty客户端如何实现心跳检测和重连机制。使用ScheduledThreadPoolExecutor线程池执行周期性任务,当长链接断开后,会进行重连尝试,确保连接稳定性。同时,详细解析了scheduleAtFixedRate和scheduleWithFixedDelay的区别。
摘要由CSDN通过智能技术生成
当客户端与服务器建立链接之后,由于网络等因素,使链接有时候不可用,怎么才能有效的检测到链接是否可用呢,这就需要用到心跳检测了。

netty客户端心跳检测发送回执如下:

4997819998245cde7f6dc92c7a2892c1.png

长链接断开后,探测到之后,需要进行尝试重连机制

86adb19b05e3151846dd7092c6c130a9.png

    心跳检测机制当然是属于系统的自身技能,不能影响到核心业务,所以就需要用到线程池技术了,准确一点就是用守护线程去守护系统的稳定性。

Java通过Executors提供四种线程池,分别为: 

1、newSingleThreadExecutor 

创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。

2、newFixedThreadPool 

创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。

3、newScheduledThreadPool 

创建一个可定期或者延时执行任务的定长线程池,支持定时及周期性任务执行。 

4、newCachedThreadPool

创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。

详细可参考下面的线程池博客文章:

https://blog.csdn.net/w05980598/article/details/79425071。

https://blog.csdn.net/achuo/article/details/80623893。

心跳检测,属于周期性的任务,我们采用ScheduledThreadPoolExecutor线程池实现。

下面例子就是源码中给出的demo:

import static java.util.concurrent.TimeUnit.*;

class BeeperControl {

   private final ScheduledExecutorService scheduler =

     Executors.newScheduledThreadPool(1);

   public void beepForAnHour() {

     final Runnable beeper = new Runnable() {

       public void run() { System.out.println("beep"); }

     };

     final ScheduledFuture> beeperHandle =

       scheduler.scheduleAtFixedRate(beeper, 10, 10, SECONDS);

     scheduler.schedule(new Runnable() {

       public void run() { beeperHandle.cancel(true); }

        }, 60 * 60, SECONDS);

   }

 }

 }

去构建一个线程池,我们采用这一种,一个核心线程数,一个线程工厂。其他构造函数,请详细查看源码。

28b2cfcee29dc8126ecffd9c76bddad1.png

这样去构建一个实例:

41b630c7cd51db62eeeabcc342d22fee.png

构建实例完成后,我们经常用的两个方法是scheduleAtFixedRate和scheduleWithFixedDelay去执行周期性或者延时性的任务。

这两个有什么区别呢,当然要先看一下源码中的注释说明。

(1)public ScheduledFuture> scheduleAtFixedRate(Runnable command,

                                                  long initialDelay,

                                                  long period,

                                                  TimeUnit unit);

方法说明:

6a0989666657d63a3a63893245411a39.png参数以及异常说明:

d0180de192ef1a50a6260ed9641c530c.png

总结一下:就是两个任务的开始执行时间的间隔是period。

(2)下面再看scheduleWithFixedDelay:

public ScheduledFuture> scheduleWithFixedDelay(Runnable command,

                                                     long initialDelay,

                                                     long delay,

                                                     TimeUnit unit);

6e231a0cdfefe12dcded4b49b14e49e2.png

参数以及异常说明:

6e9d37a5fe82bf97b57dea09caafdbe0.png

总结一下:就是上一个任务执行结束与下一个任务的开始间隔是delay。

如果任务执行的时间特别长,超过了时间间隔,那么就不能按照预期设定的间隔去执行了,延后执行了。

源码比任何技术文章都更清晰明了,所以我就贴出来部分源码,详细的还请查看源码。

之后就可以开始去实战了,写一个要执行的run任务。

4e36b69b2b8d26c1059c95be6e1f0c8f.png

探测到长链接不可用时,需要进行客户端重连机制,尽最大可能去保证链接的有效性。

cf526158b420b2026748bab38390c19c.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值