xxl-job源码阅读——(四)丢失,失败处理机制及扩展报警方式
xxl-job
xxl-job: 是一个分布式任务调度平台,核心设计目标是开发迅速、学习简单、轻量级、易扩展。
项目地址:https://gitcode.com/gh_mirrors/xx/xxl-job
免费下载资源
·
一. 丢失任务源码
在前面【执行器注册机制】中我们已经提及AdminBiz与ExecutorBiz的作用,任务的分发运行,取消,上报等也是通过这两个接口来实现。
任务“丢失”的判定如下:
- 打开JobLosedMonitorHelper.getInstance().start()
这里的检测时间时60s一次。
其他代码无歧义,不赘述了。
二. 失败任务源码
失败任务线程主要负责两件事,1-重试任务,2-任务报警。
- JobFailMonitorHelper.getInstance().start()
一进来老套路,while循环,对了,这里的toStop时一个volatile的boolean,默认为false,当spring容器停止,触发DisposableBean时会被变更为true
。
第一步,再xxl_job_log
表拿1000条为处理的失败日志。
第二步,通过CAS锁住一条日志进行操作。
第三步, 判断是否还有剩余失败重试次数,有则重试,并将次数-1,trigger具体逻辑我们到下一篇【triggerPool】时再聊。
第四步,触发邮件报警,这里我们稍加改造就可以实现短信/企微等其他报警,具体见下方
。
第五步,CAS失败当前log的锁定状态。
三. 扩展报警方式
在失败处理线程中,我们看到了JobAlarmer,我们看一下他的结构。
这里的解耦味道不错。
- JobAlarmer 是警报触发器,负责触发的动作。
- JobAlarm 的实现类是 实际警报处理器,比如此处的EmailJobAlarm实现了邮件的发送。
同理我们也可以增加一些其他方式的报警处理器:
- 需要实现JobAlarm的doAlarm方法即可。
- 如果需要发送地址,比如短信报警,可以复用页面的“报警邮件*”这一项,或者自定义,再增加一个字段,然后在新增的doAlarm里面解析使用即可。
欢迎关注微信公众号 【JAVA技术分享官】,公众号首发,持续输出原创高质量JAVA开发者知识点
GitHub 加速计划 / xx / xxl-job
27.16 K
10.79 K
下载
xxl-job: 是一个分布式任务调度平台,核心设计目标是开发迅速、学习简单、轻量级、易扩展。
最近提交(Master分支:3 个月前 )
e5d26ba2 - 3 个月前
977ad87b - 3 个月前
更多推荐
已为社区贡献6条内容
所有评论(0)