定时任务支持集群部署

This commit is contained in:
阿沐 2022-09-03 23:11:02 +08:00
parent 22e1afc2e3
commit b65e33c1e0
2 changed files with 57 additions and 1 deletions

View File

@ -0,0 +1,52 @@
package net.maku.quartz.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.quartz.SchedulerFactoryBean;
import javax.sql.DataSource;
import java.util.Properties;
/**
* 定时任务配置
*
* @author 阿沐 babamu@126.com
*/
@Configuration
public class ScheduleConfig {
@Bean
public SchedulerFactoryBean schedulerFactoryBean(DataSource dataSource) {
// quartz参数
Properties prop = new Properties();
prop.put("org.quartz.scheduler.instanceName", "MakuScheduler");
prop.put("org.quartz.scheduler.instanceId", "AUTO");
// 线程池配置
prop.put("org.quartz.threadPool.class", "org.quartz.simpl.SimpleThreadPool");
prop.put("org.quartz.threadPool.threadCount", "20");
prop.put("org.quartz.threadPool.threadPriority", "5");
// jobStore配置
prop.put("org.quartz.jobStore.class", "org.springframework.scheduling.quartz.LocalDataSourceJobStore");
// 集群配置
prop.put("org.quartz.jobStore.isClustered", "true");
prop.put("org.quartz.jobStore.clusterCheckinInterval", "15000");
prop.put("org.quartz.jobStore.maxMisfiresToHandleAtATime", "1");
prop.put("org.quartz.jobStore.txIsolationLevelSerializable", "true");
prop.put("org.quartz.jobStore.misfireThreshold", "12000");
prop.put("org.quartz.jobStore.tablePrefix", "QRTZ_");
prop.put("org.quartz.jobStore.selectWithLockSQL", "SELECT * FROM {0}LOCKS UPDLOCK WHERE LOCK_NAME = ?");
SchedulerFactoryBean factory = new SchedulerFactoryBean();
factory.setSchedulerName("MakuScheduler");
factory.setDataSource(dataSource);
factory.setQuartzProperties(prop);
// 延时启动
factory.setStartupDelay(10);
factory.setApplicationContextSchedulerContextKey("applicationContextKey");
// 启动时更新己存在的Job这样就不用每次修改targetObject后删除qrtz_job_details表对应记录了
factory.setOverwriteExistingJobs(true);
return factory;
}
}

View File

@ -5,6 +5,8 @@ import lombok.Data;
import lombok.EqualsAndHashCode; import lombok.EqualsAndHashCode;
import net.maku.framework.common.entity.BaseEntity; import net.maku.framework.common.entity.BaseEntity;
import java.io.Serializable;
/** /**
* 定时任务 * 定时任务
* *
@ -13,7 +15,9 @@ import net.maku.framework.common.entity.BaseEntity;
@Data @Data
@EqualsAndHashCode(callSuper=false) @EqualsAndHashCode(callSuper=false)
@TableName("schedule_job") @TableName("schedule_job")
public class ScheduleJobEntity extends BaseEntity { public class ScheduleJobEntity extends BaseEntity implements Serializable {
private static final long serialVersionUID = 1L;
/** /**
* 任务名称 * 任务名称
*/ */