netty客户端心跳检测发送回执如下:
长链接断开后,探测到之后,需要进行尝试重连机制
心跳检测机制当然是属于系统的自身技能,不能影响到核心业务,所以就需要用到线程池技术了,准确一点就是用守护线程去守护系统的稳定性。
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);
}
}
}
去构建一个线程池,我们采用这一种,一个核心线程数,一个线程工厂。其他构造函数,请详细查看源码。
这样去构建一个实例:
构建实例完成后,我们经常用的两个方法是scheduleAtFixedRate和scheduleWithFixedDelay去执行周期性或者延时性的任务。
这两个有什么区别呢,当然要先看一下源码中的注释说明。
(1)public ScheduledFuture> scheduleAtFixedRate(Runnable command,
long initialDelay,
long period,
TimeUnit unit);
方法说明:
参数以及异常说明:
总结一下:就是两个任务的开始执行时间的间隔是period。
(2)下面再看scheduleWithFixedDelay:
public ScheduledFuture> scheduleWithFixedDelay(Runnable command,
long initialDelay,
long delay,
TimeUnit unit);
参数以及异常说明:
总结一下:就是上一个任务执行结束与下一个任务的开始间隔是delay。
如果任务执行的时间特别长,超过了时间间隔,那么就不能按照预期设定的间隔去执行了,延后执行了。
源码比任何技术文章都更清晰明了,所以我就贴出来部分源码,详细的还请查看源码。
之后就可以开始去实战了,写一个要执行的run任务。
探测到长链接不可用时,需要进行客户端重连机制,尽最大可能去保证链接的有效性。