定时任务支持集群部署
This commit is contained in:
parent
22e1afc2e3
commit
b65e33c1e0
|
@ -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;
|
||||||
|
}
|
||||||
|
}
|
|
@ -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;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 任务名称
|
* 任务名称
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in New Issue
Block a user