Elastic-Job项目源码分析2--console执行一窥

我们先来看下console的界面,简洁无华,两个维度以及基本的配置和操作。该有的基本都有了,还没有的估计在开发中,哈哈
这里写图片描述

今天我们研究的话题,触发按钮到底做了什么,如果你还不了解,请听我娓娓道来。

从架构上来看,console没有和elastic-job-lite发生直接的联系,而是借助ZK和 Elastic-job-lite联系了在一起
这里写图片描述

但是大家注意到Elastic-Job-Lite和zk怎么联系在一起的么?是的Listener 就是它。当Console增加或修改了zk上的节点时(这里指的是jobName节点下的节点和数据变动,感谢严欢欢同学指出),就会触发Listener,进而触发Job的相关的操作,如触发、暂停、恢复等等,有了这些。明白了原理,我们来看看代码,
Talk is cheap, show me code!

  • console UI 点击触发按钮 做了什么?

这里写图片描述
请求了/elastic-job-lite-console/job/trigger 这个接口,我们来瞧瞧这个Controller
在这里 elastic-job\elastic-job-lite\elastic-job-lite-console\src\main\java\com\dangdang\ddframe\job\lite\console\controller\JobOperationController.java

这里写图片描述

再找到这里Trigger的实现类
elastic-job\elastic-job-lite\elastic-job-lite-lifecycle\src\main\java\com\dangdang\ddframe\job\lite\lifecycle\internal\operate\JobOperateAPIImpl.java

这里写图片描述

我擦,原来亮哥,是在这个serverIp下插入了一个trigger节点,就完事了,是不是so easy?(后记:实际中我们没有并看到trigger节点,这是因为执行程序速度很快,你还没有看到节点,代码已经删除这个节点了,可以看JobTriggerStatusJobListener 中的代码,稍后会讲到)

  • Elastic-Job-Lite 是如何执行的?

这里写图片描述

这里写图片描述

我们先来看下基类AbstractJobListener做了什么。

这里写图片描述

我擦,原来继承了TreeCacheListener 用过curator的都知道这个吧,题外话,除了它,还有NodeCachePathCache,请读者自行阅读其使用方式。好了,谜底都差不多了,再回到JobTriggerStatusJobListener

这里写图片描述

  • 要点1 serverService.clearJobTriggerStatus(); 这里清除了trigger节点,所以大家看不到trigger节点了
  • 要点2 这里的jobScheduleController.triggerJob() 其实就是调用了quartz里的方法,一起来看看

这里写图片描述

为什么这里会有scheduler,jobDetail,这玩意,因为,一个job信息包含只有一个线程的quartz,还记得上篇quartz的ThreadCount为1吗?也就是说n个job就会有n个quartz实例~~~

好了,console上的Trigger按钮事件就分析完了,欢迎大家指正交流!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值