说明:本篇文章部分内容参考了网上的文章(在下文已给出原文链接),由于本人能力有限,如果有书写错误的地方,欢迎各位大佬批评指正!我们互相交流,学习,共同进步!
该项目的地址:https://github.com/xiaoheng1/nacos_read
关于 Nacos 任务执行引擎的设计
// 任务的抽象.
public interface NacosTask {
/**
* Judge Whether this nacos task should do.
*
* @return true means the nacos task should be done, otherwise false
*/
boolean shouldProcess();
}
NacosTask 分为两类,AbstractExecuteTask 和 AbstractDelayTask.
AbstractDelayTask 可以延迟和合并任务的抽象. 怎么理解了?可以看下 shouldProcess 方法,等于(当前时间-上次执行时间) >= 执行间隔,则允许执行.
AbstractExecuteTask 立即执行任务的抽象.
// Nacos 任务执行引擎
public interface NacosTaskExecuteEngine extends Closeable {
/**
* Get Task size in execute engine.
*
*