SpringBoot集成ElasticJob实现任务的动态添加

需求 - 定时任务需要通过页面来添加 环境 - SpringBoot、ElasticJob 开发 - 引入ElasticJob、zookeeper pom

<dependency>
    <groupId>com.dangdang</groupId>
    <artifactId>elastic-job-lite-core</artifactId>
    <version>2.1.5</version>
</dependency>
<dependency>
    <groupId>com.dangdang</groupId>
    <artifactId>elastic-job-lite-spring</artifactId>
    <version>2.1.5</version>
</dependency>
<dependency>
    <groupId>org.apache.zookeeper</groupId>
    <artifactId>zookeeper</artifactId>
    <version>3.4.8</version>
</dependency>

配置ElasticJobConfig(其中spring.elasticjob.serverList、spring.elasticjob.namespace为配置项)

@Configuration
@ConditionalOnExpression("'${spring.elasticjob.serverList}'.length() > 0")
public class ElasticJobConfig {
	
	@Autowired
    private DataSource dataSource;
	
	@Bean(initMethod = "init")
    public ZookeeperRegistryCenter regCenter(@Value("${spring.elasticjob.serverList}") final String serverList, @Value("${spring.elasticjob.namespace}") final String namespace) {
        return new ZookeeperRegistryCenter(new ZookeeperConfiguration(serverList, namespace));
    }
	
    @Bean
    public JobEventConfiguration jobEventConfiguration() {
        return new JobEventRdbConfiguration(dataSource);
    }
}

添加job片段

JobCoreConfiguration coreConfig = JobCoreConfiguration.newBuilder(taskNo, DateHelper.getCron(taskVO.getExecuteTime()), 1).build();
SimpleJobConfiguration simpleJobConfig = new SimpleJobConfiguration(coreConfig, DynamicAddJob.class.getCanonicalName());

JobScheduler jobScheduler = new JobScheduler(regCenter, LiteJobConfiguration.newBuilder(simpleJobConfig).build());

jobScheduler.init();

DynamicAddJob代码片段

public class DynamicAddJob implements SimpleJob {
    @Override
    public void execute(ShardingContext shardingContext) {
        String jobName = shardingContext.getJobName();//获取Job名称
        ......
    }
}

转载于:https://my.oschina.net/u/3694704/blog/1629924

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值