温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

springboot实现多实例crontab抢占定时任务代码分享

发布时间:2021-08-31 15:00:13 来源:亿速云 阅读:291 作者:chen 栏目:编程语言

这篇文章主要介绍“springboot实现多实例crontab抢占定时任务代码分享”,在日常操作中,相信很多人在springboot实现多实例crontab抢占定时任务代码分享问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”springboot实现多实例crontab抢占定时任务代码分享”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

利用redisson实现多实例抢占定时任务

pom.xml
<dependency>   <groupId>org.redisson</groupId>   <artifactId>redisson</artifactId>   <version>3.12.0</version></dependency>
Kernel.java - 重写多线程调度
package com.brand.log.scheduler;import org.springframework.context.annotation.Configuration;import org.springframework.scheduling.annotation.SchedulingConfigurer;import org.springframework.scheduling.config.ScheduledTaskRegistrar;import java.util.concurrent.Executors;@Configurationpublic class Kernel implements SchedulingConfigurer { @Override public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {  //设定一个长度10的定时任务线程池  taskRegistrar.setScheduler(Executors.newScheduledThreadPool(4)); }}
RedissonManager.java - 分布式锁的实现
package com.brand.log.util;import lombok.extern.slf4j.Slf4j;import org.redisson.Redisson;import org.redisson.config.Config;import org.springframework.beans.factory.annotation.Value;import org.springframework.stereotype.Component;import javax.annotation.PostConstruct;@Component@Slf4jpublic class RedissonManager { @Value("${spring.redis.host}") private String host; @Value("${spring.redis.port}") private int port; private Redisson redisson = null; private Config config = new Config(); @PostConstruct private void init() {  try {   config.useSingleServer().setAddress("redis://" + host + ":" + port);   log.info("redisson address {} {}", host, port);   redisson = (Redisson) Redisson.create(config);   log.info("Redisson 初始化完成");  }  catch (Exception e) {   log.error("init Redisson error ", e);  } } public Redisson getRedisson() {  return redisson; }}
CronSynData.java
package com.brand.log.scheduler;import com.brand.log.util.DateFormatV1;import com.brand.log.util.RedisUtil;import com.brand.log.util.RedissonManager;import lombok.extern.slf4j.Slf4j;import org.redisson.Redisson;import org.redisson.api.RLock;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.scheduling.annotation.Scheduled;import org.springframework.stereotype.Component;import java.util.concurrent.TimeUnit;@Component@Slf4jpublic class CronSynData { @Autowired RedissonManager redissonManager; @Autowired RedisUtil redisUtil; @Autowired DateFormatV1 dateFormatV1; private String lokFlag = ".handleKernel"; private Redisson redisson = null; /* * java定时脚本挂靠实例 * 多实例会有重复调用问题 + 使用Redisson实现分布式锁 * 业务逻辑必须加锁 + 且需要保证 tryLock 等待时间小于cron的最小间隔执行时间 * */ @Scheduled(cron = "*/10 * * * * *") public void handleKernel() {  redisson = redissonManager.getRedisson();  if (redisson != null) {   RLock lock = redisson.getLock(this.getClass().getName() + lokFlag);   Boolean stat = false;   try {    // 尝试加锁,立即返回,最多等待5s自动解锁    stat = lock.tryLock(0, 5, TimeUnit.SECONDS);    if (stat) {     log.info("{} 取锁成功!{}",this.getClass().getName(), Thread.currentThread().getName());     redisUtil.checkCount("log:limit_", dateFormatV1.getDate("HH", "GMT+8"), 60*10, 1000);    } else {     log.info("{}没有获取到锁:{}", this.getClass().getName(), Thread.currentThread().getName());    }   } catch (InterruptedException e) {    log.error("Redisson 获取分布式锁异常", e);    if (!stat){     return;    }    lock.unlock();   }  } }}

kibana - 6个实例

到此,关于“springboot实现多实例crontab抢占定时任务代码分享”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI