# Spring Boot 集成 Elastic-Job

作者:Tom哥
公众号:微观技术
博客:https://offercome.cn (opens new window)
人生理念:知道的越多,不知道的越多,努力去学

Spring Boot 作为主流微服务框架,拥有成熟的社区生态。市场应用广泛,为了方便大家,整理了一个基于spring boot的常用中间件快速集成入门系列手册,涉及RPC、缓存、消息队列、分库分表、注册中心、分布式配置等常用开源组件,大概有几十篇文章,陆续会开放出来,感兴趣同学可以关注&收藏

# 简介

Elasticjob是一个开源的分布式调度解决方案。Elasticjob由两个相互独立的子项目Elastic-Job-Lite和Elastic-Job-Cloud组成。Elastic-Job-Lite定位为轻量级无中心化解决方案,使用jar包的形式提供分布式任务的协调服务;Elastic-Job-Cloud采用自研 Mesos Framework的解决方案,额外提供资源治理、应用分发以及进程隔离等功能。

Elastic-Job-Lite,它支持多种任务类型,支持任务分片,可以将任务拆分成多个子任务,像原先介绍的Quartz集群方案中可能存在的任务处理的单机极限问题,可以利用Elastic-Job-Lite解决,可以通过预先分配分片项参数,任务分片后,每个分片任务只处理跟自己相关的分片数据,这样就可以将单机处理的数据,分散成多机处理,缓解压力。Elastic-Job还支持分片级别的故障切换,具有容错性,一个分片任务故障后,可以被其他机器的任务接管,继续执行分片任务。

# 代码演示

# 外部依赖

在 pom.xml 文件中添加 Elastic-Job 依赖:

<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>
    <exclusions>
        <exclusion>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-client</artifactId>
        </exclusion>
    </exclusions>
</dependency>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

# 配置文件

在配置文件 application.yaml 中配置 Elastic-Job 的相关参数,具体内容如下:

elasticjob:
  zk: 127.0.0.1:2181
  namespace: ej
1
2
3

# Elastic-Job 配置类

@Bean
public CoordinatorRegistryCenter regCenter() {
    CoordinatorRegistryCenter regCenter = new ZookeeperRegistryCenter(new ZookeeperConfiguration(zk, nameSpace));
    regCenter.init();
    return regCenter;
}

private LiteJobConfiguration getLiteJobConfiguration(final Class<? extends SimpleJob> jobClass, final String cron) {
    return LiteJobConfiguration.newBuilder(
            new SimpleJobConfiguration(JobCoreConfiguration
                    .newBuilder(jobClass.getSimpleName(), cron, 1)
                    .shardingItemParameters("1=1")
                    .build(), jobClass.getCanonicalName()))
            .overwrite(true)
            .build();
}

@Bean(initMethod = "init")
public JobScheduler createBrandActivityJobSchedule(final UserCountJob userCountJob, CoordinatorRegistryCenter regCenter) {
    return new SpringJobScheduler(userCountJob, regCenter,
            getLiteJobConfiguration(userCountJob.getClass(),
                    // 每10秒执行一次
                    "*/10 * * * * ? *"), new TimeStatisticsListener());
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

# 编写 Job 任务

框架预留扩展接口com.dangdang.ddframe.job.api.simple.SimpleJob,定义业务类UserCountJob,然后在execute() 方法中实现我们的业务逻辑。

@Slf4j
@Component
public class UserCountJob implements SimpleJob {

    @Override
    public void execute(ShardingContext shardingContext) {
        // 分片上下文参数
        System.out.println("ShardingContext:" + JSON.toJSONString(shardingContext));
        long userCount = 1200;
        System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()) + " 用户注册数:" + userCount);
    }
}
1
2
3
4
5
6
7
8
9
10
11
12

# Elastic-Job 控制台

控制台地址:

http://localhost:8899/#

  • 配置 zookeeper 注册中心
  • 客户端系统启动时,会自动上报 Job 任务

# 项目源码

https://github.com/aalansehaiyang/spring-boot-bulking  

模块:spring-boot-bulking-elasticjob
1
2
3
上次更新: 2023/3/4