SpringBoot + Quartz 集成
Quartz
应用启动加载集群配置
@Bean
注解交由Spring BeanFactory
容器管理@Bean
public JobDetailFactoryBean testJobDetailFactory() {
JobDetailFactoryBean jobDetailFactory = new JobDetailFactoryBean();
jobDetailFactory.setName("test-job");
jobDetailFactory.setGroup("sns");
jobDetailFactory.setJobClass(TestJob.class);
jobDetailFactory.setDurability(true);
return jobDetailFactory;
} @Bean
public CronTriggerFactoryBean testJobTrigger(
@Qualifier("testJobDetailFactory") JobDetailFactoryBean factory) {
CronTriggerFactoryBean tigger = new CronTriggerFactoryBean();
if (factory.getObject() != null) {
tigger.setJobDetail(factory.getObject());
}
tigger.setCronExpression("0/10 * * * * ?");
tigger.setName("test-job-trigger");
return tigger;
}/**
* SchedulerFactoryBean 实现 InitializingBean,
* description: quartz定时任务配置
*/
@Configuration
public class QuartzConfig {
private static final Logger LOGGER = LoggerFactory.getLogger(QuartzConfig.class);
private static final String RESOURCE_NAME = "quartz.properties"; @Resource
private DataSource dataSource;
@Autowired
private SpringJobFactory springJobFactory; @Bean
public SchedulerFactoryBean schedulerFactory(Trigger... triggers) {
SchedulerFactoryBean factory = new SchedulerFactoryBean();
Properties p = new Properties();
try {
p.load(this.getClass().getClassLoader().getResourceAsStream(RESOURCE_NAME));
} catch (IOException e) {
LOGGER.error("quartz定时任务加载{}过程中发生错误。");
throw new Error(e);
}
factory.setQuartzProperties(p);
factory.setDataSource(dataSource);
factory.setOverwriteExistingJobs(true);
factory.setStartupDelay(20);
factory.setTriggers(triggers);
factory.setJobFactory(springJobFactory);
return factory;
}
}实现
org.springframework.boot.CommandLineRunner
,应用启动成功后开启创建任务@Component
public class InitScheduleOfAppStarted implements CommandLineRunner {
private static final Logger LOGGER = LoggerFactory.getLogger(InitScheduleOfAppStarted.class); @Autowired
private SysJobService sysJobService;
// 任务 Bean 交由 Spring 管理,并注入任务所需的 Bean 实例
@Autowired
private SpringJobFactory springJobFactory; @Override
public void run(String... args) throws Exception {
Map<String, String> runJob = new HashMap();
runJob.put("jobStatus", "1");
List<SysJob> jobList = sysJobService.querySysJobList(runJob); if (null == jobList || jobList.size() <= 0) {
LOGGER.info("app started,暂无需要执行的任务");
} SchedulerFactory sf = new StdSchedulerFactory();
Scheduler scheduler = sf.getScheduler();
// 注入 spring 示例,否则执行时找不到 spring 容器中的 bean
scheduler.setJobFactory(springJobFactory);
scheduler.start(); for (SysJob sysJob : jobList) { // jobDetail
String jobName = sysJob.getJobName();
String jobGroup = sysJob.getJobGroup();
JobDetail jobDetail = JobBuilder.newJob(getClass(sysJob.getJobClassPath()).getClass())
.withIdentity(jobName, jobGroup)
.build();
// jobTriller
CronTrigger cronTrigger = TriggerBuilder.newTrigger()
.withIdentity(jobName, jobGroup)
.withSchedule(CronScheduleBuilder.cronSchedule(sysJob.getJobCron()))
.build();
// 关联
scheduler.scheduleJob(jobDetail, cronTrigger);
}
} private static Job getClass(String jobClassPath) throws Exception{
Class<?> aClass = Class.forName(jobClassPath);
return (Job) aClass.newInstance();
}
}继承
org.springframework.scheduling.quartz.AdaptableJobFactory
实例化和依赖注入 Spring Bean 实例@Component
public class SpringJobFactory extends AdaptableJobFactory { @Autowired
private AutowireCapableBeanFactory capableBeanFactory; @Override
protected Object createJobInstance(TriggerFiredBundle bundle) throws Exception {
Object jobInstance = super.createJobInstance(bundle);
capableBeanFactory.autowireBean(jobInstance);
return jobInstance;
}
}
SpringBoot + Quartz 集成的更多相关文章
- SpringBoot定时任务 - 集成quartz实现定时任务(单实例和分布式两种方式)
最为常用定时任务框架是Quartz,并且Spring也集成了Quartz的框架,Quartz不仅支持单实例方式还支持分布式方式.本文主要介绍Quartz,基础的Quartz的集成案例本,以及实现基于数 ...
- spring-boot-2.0.3之quartz集成,不是你想的那样哦!
前言 开心一刻 晚上回家,爸妈正在吵架,见我回来就都不说话了,看见我妈坐在那里瞪着我爸,我就问老爸“你干什么了惹我妈生这么大气?” 我爸说“没有什么啊,倒是你,这么大了还没有媳妇,要是你有媳妇给我们 ...
- spring-boot-2.0.3之quartz集成,数据源问题,源码探究
前言 开心一刻 着火了,他报警说:119吗,我家发生火灾了. 119问:在哪里? 他说:在我家. 119问:具体点. 他说:在我家的厨房里. 119问:我说你现在的位置. 他说:我趴在桌子底下. 11 ...
- spring-boot-2.0.3之quartz集成,最佳实践
前言 开心一刻 快过年了,大街上,爷爷在给孙子示范摔炮怎么放,嘴里还不停念叨:要像这样,用劲甩才能响.示范了一个,两个,三个... 孙子终于忍不住了,抱着爷爷的腿哭起来:爷呀,你给我剩个吧! 新的一年 ...
- spring-boot+quartz的CRUD动态任务管理系统
版权声明:作者: 小柒 出处: https://blog.52itstyle.com 分享是快乐的,也见证了个人成长历程,文章大多都是工作经验总结以及平时学习积累,基于自身认知不足之处在所难免,也请大 ...
- Springboot+Quartz+druid+多库
很久以前就用过quartz,现在重新用起,主要实现集群方式启动,并且支持多数据源注入到job中.网上demo很多,方法大同小异.但关于数据源注入的深入介绍不多,不错的文章:<spring-boo ...
- Quartz集成springMVC 的方案二(持久化任务、集群和分布式)
Quartz是一个开放源码项目,专注于任务调度器,提供了极为广泛的特性如持久化任务,集群和分布式任务等. Quartz核心是调度器,还采用多线程管理. 1.持久化任务:当应用程序停止运行时,所有调度信 ...
- Quartz集成springMVC 的方案一
Quartz是一个开放源码项目,专注于任务调度器. springMVC 具体的搭建框架就不具体说明,接下来直接描述把Quartz集成到springMVC 框架中. 步骤: 1.引入所需要的jar包 2 ...
- ABP文档 - Quartz 集成
文档目录 本节内容: 简介 安装 创建工作 调度工作 更多 简介 Quartz 是一个功能完整的开源工作调度系统,可用于最小的应用到一个大型的企业系统.Abp.Quartz 包简单地把Quartz集成 ...
- Quartz学习——SSMM(Spring+SpringMVC+Mybatis+Mysql)和Quartz集成详解(四)
当任何时候觉你得难受了,其实你的大脑是在进化,当任何时候你觉得轻松,其实都在使用以前的坏习惯. 通过前面的学习,你可能大致了解了Quartz,本篇博文为你打开学习SSMM+Quartz的旅程!欢迎上车 ...
随机推荐
- 谈谈Selenium中的三种切换之alert
谈谈Selenium中的三种切换之alert 一.如何识别 识别方法:alert中的确定.取消.输入框无法用inspector定位到,当然还有一些特例. alert分为三种 alert confirm ...
- websocket-sharp 实现websocket
第一步,使用VS创建一个应用程序 第二步,添加引用 websocket-sharp DLL文件,或者NuGet程序包中添加 第三部,创建Laputa 类 using WebSocketSharp; u ...
- 使用HtmlAgilityPack 爬取 国家统计局 区划和城乡划分代码
HtmlAgilityPack:Html解析神器,根据url地址解析html页面内容. 项目引用HtmlAgilityPack.dll文件或者通过安装 nuget 包 HtmlAgilityPack ...
- 【TS】object类型
object是一个对象,在ts中定义对象类型的语法为:let 变量名 :object = { } 在object类型中,对象内部定义的值是不受类型约束的,只要是一个object类型即可,例如: let ...
- LinkedList内部实现原理
LinkedList内部实现原理 java list 同ArrayList内部原理一样 我们先创建一个LinkedList对象LinkedList<String> li = new Lin ...
- 题解 [SHOI2002] 百事世界杯之旅
其实做这道题还蛮难受的...因为这个每一次有无限种可能我有钱我可以去买无限瓶可乐啊但是不是可口我不是很赞同┓( ´∀` )┏ 然后参考了这篇题解发现错位相减这样的方法,让我们一起膜拜 Butterfl ...
- Vulhub 漏洞学习之:AppWeb
Vulhub 漏洞学习之:AppWeb 目录 Vulhub 漏洞学习之:AppWeb 1 AppWeb认证绕过漏洞(CVE-2018-8715) 1.1 漏洞利用原理 1.2 漏洞利用过程 1 App ...
- 初学 Socket.io
概念 Socket.io 是一个支持客户端和服务器之间的低延迟.双向和基于事件的通信的库,除了支持 JavaScript 以外,还支持 Java.Python.Golang. Socket.io 构建 ...
- Cesium之基础控件
1. 引言 Cesium是一款三维地球和地图可视化开源JavaScript库,使用WebGL来进行硬件加速图形,使用时不需要任何插件支持,基于Apache2.0许可的开源程序,可以免费用于商业和非商业 ...
- 开源分布式任务调度系统就选:DolphinScheduler
分布式任务调度这个话题是每个后端开发和大数据开发都会接触的话题.因为应用场景的广泛,所以有很多开源项目专注于解决这类问题,比如我们熟知的xxl-job. 那么今天要给大家推荐的则是另一个更为强大的开源 ...