ZBLOG

@Override protected void executeInternal(JobExecutionContext executionContext) throws JobExecutionException { // 第一步,获得 Job 数据 Long jobId = executionContext.getMergedJobDataMap().getLong(JobDataKeyEnum.JOB_ID.name()); S...

这段代码是一个 Quartz 定时任务中的 executeInternal 方法,用于在执行任务时获取任务相关的数据。下面是对各个步骤的说明:

  1. 获得 Job 数据 使用 getMergedJobDataMap() 方法来获取 JobDetail 中与 Trigger 中合并后的 JobDataMap 对象,并从中读取需要的数据。其中,JobDataKeyEnum 是一个枚举类型,它定义了可能被使用的 key 的名称。

  2. 获取 jobId 通过调用 getLong() 方法获取 Long 类型的值,并将其赋给 jobId 变量。

  3. 获取 jobHandlerName 和 jobHandlerParam 通过调用 getString() 方法分别获取处理器类名和参数,并将它们赋给 jobHandlerName 和 jobHandlerParam 变量。

  4. 获取 refireCount refireCount 表示当前触发器已经重新触发执行了多少次(包括当前这一次)。可以通过 executionContext.getRefireCount() 方法获得该值。

  5. 获取 retryCount 和 retryInterval retryCount 表示当任务失败时重试次数,默认为 0;retryInterval 表示每次重试之间的时间间隔,默认为 0。如果没有设置,则会使用 getOrDefault() 方法提供默认值。

总之,以上代码展示了如何在 Quartz 定时任务中获取一些与任务相关的数据,以便进行后续处理。

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=2997

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?