亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

SpringBoot集成ElaticJob定時器的實現代碼

2024-07-14 08:41:15
字體:
來源:轉載
供稿:網友

本文介紹了SpringBoot集成ElaticJob定時器的實現代碼,分享給大家,具體如下:

POM文件配置

<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0"     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"     xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">  <modelVersion>4.0.0</modelVersion>  <groupId>com.example</groupId>  <artifactId>demojob</artifactId>  <version>0.0.1-SNAPSHOT</version>  <packaging>jar</packaging>  <name>demojob</name>  <description>Demo project for Spring Boot</description>  <parent>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-parent</artifactId>    <version>2.0.2.RELEASE</version>    <relativePath/> <!-- lookup parent from repository -->  </parent>  <properties>    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>    <java.version>1.8</java.version>  </properties>  <dependencies>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-web</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-test</artifactId>      <scope>test</scope>    </dependency>    <!--elastic-job-->    <dependency>      <artifactId>elastic-job-common-core</artifactId>      <groupId>com.dangdang</groupId>      <version>2.1.5</version>    </dependency>    <dependency>      <artifactId>elastic-job-lite-core</artifactId>      <groupId>com.dangdang</groupId>      <version>2.1.5</version>    </dependency>    <dependency>      <artifactId>elastic-job-lite-spring</artifactId>      <groupId>com.dangdang</groupId>      <version>2.1.5</version>    </dependency>    <dependency>      <artifactId>elastic-job-cloud-executor</artifactId>      <groupId>com.dangdang</groupId>      <version>2.1.5</version>    </dependency>    <!--mariadb-->    <dependency>      <groupId>org.mariadb.jdbc</groupId>      <artifactId>mariadb-java-client</artifactId>      <version>1.5.4</version>    </dependency>    <!--druid-->    <dependency>      <groupId>com.alibaba</groupId>      <artifactId>druid-spring-boot-starter</artifactId>      <version>1.1.9</version>    </dependency>    <!--mybatis plus-->    <dependency>      <groupId>com.baomidou</groupId>      <artifactId>mybatisplus-spring-boot-starter</artifactId>      <version>1.0.5</version>    </dependency>    <dependency>      <groupId>com.baomidou</groupId>      <artifactId>mybatis-plus</artifactId>      <version>2.1.9</version>    </dependency>  </dependencies>  <build>    <plugins>      <plugin>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-maven-plugin</artifactId>      </plugin>    </plugins>  </build></project>

yaml文件配置(也可以用application.properties一樣的)

# 配置配置數據源spring: datasource:  type: com.alibaba.druid.pool.DruidDataSource  driver-class-name: org.mariadb.jdbc.Driver  name: elastic-job-event  url: jdbc:mariadb://127.0.0.1:3306/elasticjob  username: root  password: 123456  druid:   validationQuery: SELECT 1   initialSize: 10   minIdle: 10   maxActive: 200   minEvictableIdleTimeMillis: 180000   testOnBorrow: false   testWhileIdle: true   removeAbandoned: true   removeAbandonedTimeout: 1800   logAbandoned: true   poolPreparedStatements: true   maxOpenPreparedStatements: 100# 配置ZookeeperregCenter: serverList: localhost:2181 namespace: hulk_order_task# 配置定時器規則simpleJob: cron: 0/5 * * * * ? shardingTotalCount: 1 shardingItemParameters: 0=1

開始寫代碼

RegistryCenterConfig

package com.example.demojob.config;import com.dangdang.ddframe.job.reg.zookeeper.ZookeeperConfiguration;import com.dangdang.ddframe.job.reg.zookeeper.ZookeeperRegistryCenter;import org.springframework.beans.factory.annotation.Value;import org.springframework.boot.autoconfigure.condition.ConditionalOnExpression;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;/** * 注冊中心配置 * 用于注冊和協調作業分布式行為的組件,目前僅支持Zookeeper。 * @author shudalei */@Configuration@ConditionalOnExpression("'${regCenter.serverList}'.length() > 0")public class RegistryCenterConfig {  @Bean(initMethod = "init")  public ZookeeperRegistryCenter regCenter(@Value("${regCenter.serverList}") final String serverList,                       @Value("${regCenter.namespace}") final String namespace) {    return new ZookeeperRegistryCenter(new ZookeeperConfiguration(serverList, namespace));  }}

JobEventConfig

package com.example.demojob.config;import com.dangdang.ddframe.job.event.JobEventConfiguration;import com.dangdang.ddframe.job.event.rdb.JobEventRdbConfiguration;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import javax.annotation.Resource;import javax.sql.DataSource;/** * 如果想把作業運行的內容寫到DB中,我們需要用到另一個構造器, * 同時定義自己的JobEventConfiguration, * 目前來說實現這個接口的只有一個類JobEventRdbConfiguration, * 通過這個可以將作業運行的痕跡進行持久化到DB的操作。 * @author shudalei */@Configurationpublic class JobEventConfig {  @Resource  private DataSource dataSource;  @Bean  public JobEventConfiguration jobEventConfiguration() {    return new JobEventRdbConfiguration(dataSource);  }}

SimpleJobConfig

package com.example.demojob.config;import com.dangdang.ddframe.job.config.JobCoreConfiguration;import com.dangdang.ddframe.job.config.simple.SimpleJobConfiguration;import com.dangdang.ddframe.job.event.JobEventConfiguration;import com.dangdang.ddframe.job.lite.api.JobScheduler;import com.dangdang.ddframe.job.lite.config.LiteJobConfiguration;import com.dangdang.ddframe.job.lite.spring.api.SpringJobScheduler;import com.dangdang.ddframe.job.reg.zookeeper.ZookeeperRegistryCenter;import com.example.demojob.job.TestSimpleJob;import org.springframework.beans.factory.annotation.Value;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import javax.annotation.Resource;@Configurationpublic class SimpleJobConfig {  /**   * 注冊中心   */  @Resource  private ZookeeperRegistryCenter regCenter;  /**   * job事件配置   */  @Resource  private JobEventConfiguration jobEventConfiguration;  /**   * 微信access token獲取任務對象   *   */  @Resource  private TestSimpleJob simpleJob;  /**   *   * @param cron 定時任務cron配置   * @param shardingTotalCount 任務分片數   * @param shardingItemParameters 任務分片參數   * @return JobScheduler 任務調度器   */  @Bean(initMethod = "init")  public JobScheduler simpleJobScheduler(@Value("${simpleJob.cron}") final String cron,                      @Value("${simpleJob.shardingTotalCount}") final int shardingTotalCount,                      @Value("${simpleJob.shardingItemParameters}") final String shardingItemParameters) {    return new SpringJobScheduler(simpleJob, regCenter,        getLiteJobConfiguration(simpleJob.getClass(), cron, shardingTotalCount, shardingItemParameters),        jobEventConfiguration);  }  /**   *   * @param jobClass 任務調度類   * @param cron 定時任務cron配置   * @param shardingTotalCount 任務分片數   * @param shardingItemParameters 任務分片參數   * @return LiteJobConfiguration 任務配置   */  private LiteJobConfiguration getLiteJobConfiguration(final Class<? extends com.dangdang.ddframe.job.api.simple.SimpleJob> jobClass, final String cron,                             final int shardingTotalCount, final String shardingItemParameters) {    return LiteJobConfiguration        .newBuilder(            new SimpleJobConfiguration(JobCoreConfiguration.newBuilder(jobClass.getName(), cron, shardingTotalCount)                .shardingItemParameters(shardingItemParameters).build(), jobClass.getCanonicalName()))        .overwrite(true).build();  }}

TestSimpleJob,定時器任務本身

package com.example.demojob.job;import com.dangdang.ddframe.job.api.ShardingContext;import com.dangdang.ddframe.job.api.simple.SimpleJob;import org.springframework.stereotype.Component;@Componentpublic class TestSimpleJob implements SimpleJob {  private int count;  //任務就是每5秒執行一次控制臺輸出1,2,3……  @Override  public void execute(ShardingContext shardingContext) {    count++;    System.out.println("task " + count);  }}

最后在Docker下安裝 Zookeeper

安裝腳本compose文件如下

version: '2'services: zookeeper01:  image: zookeeper  restart: always  hostname: zookeeper01  ports:   - 2181:2181  environment:   ZOO_MY_ID: 1   ZOO_SERVERS: server.1=0.0.0.0:2888:3888 server.2=zookeeper02:2888:3888 server.3=zookeeper03:2888:3888 zookeeper02:  image: zookeeper  restart: always  hostname: zookeeper02  ports:   - 2182:2181  environment:   ZOO_MY_ID: 2   ZOO_SERVERS: server.1=zookeeper01:2888:3888 server.2=0.0.0.0:2888:3888 server.3=zookeeper03:2888:3888 zookeeper03:  image: zookeeper  restart: always  hostname: zookeeper03  ports:   - 2183:2181  environment:   ZOO_MY_ID: 3   ZOO_SERVERS: server.1=zookeeper01:2888:3888 server.2=zookeeper02:2888:3888 server.3=0.0.0.0:2888:3888

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
性欧美在线看片a免费观看| 精品国产91久久久久久老师| 亚洲欧洲在线观看| 91精品视频专区| 91精品国产777在线观看| 亚洲人成在线观看网站高清| 在线中文字幕日韩| 国产亚洲精品美女久久久久| 欧美国产极速在线| 日本精品久久久| 97国产精品免费视频| 欧美老肥婆性猛交视频| 成人字幕网zmw| 国产成人欧美在线观看| 91性高湖久久久久久久久_久久99| 黄色精品一区二区| 欧美国产欧美亚洲国产日韩mv天天看完整| 成人黄色av网| 国内外成人免费激情在线视频网站| 亚洲欧美国产一本综合首页| 亚洲高清久久久久久| 亚洲日本中文字幕| 色婷婷综合久久久久| 久久久人成影片一区二区三区| 亚洲专区国产精品| 亚洲色图15p| 欧美日韩国产一中文字不卡| 国产91成人在在线播放| 国产欧美日韩91| 日韩精品一二三四区| 国产精品网红直播| 91香蕉亚洲精品| 国产一级揄自揄精品视频| 一区二区三区黄色| 97人人爽人人喊人人模波多| 日韩精品免费在线播放| 亚洲国产精品久久91精品| 国产精品午夜一区二区欲梦| 国产精品视频最多的网站| 91av网站在线播放| 亚洲自拍偷拍网址| 38少妇精品导航| 国模叶桐国产精品一区| 日韩精品在线免费播放| 国产精品第100页| 国产精品久久久久99| 91精品啪在线观看麻豆免费| 日韩在线免费观看视频| 亚洲人成电影在线播放| 高清欧美性猛交xxxx黑人猛交| 久久久久亚洲精品| 北条麻妃一区二区在线观看| 日韩av黄色在线观看| 亚洲天堂视频在线观看| 国产综合在线看| 亚洲女同性videos| 最近2019中文字幕大全第二页| 久久久伊人欧美| 91精品在线一区| 久久99热这里只有精品国产| 少妇久久久久久| 国产精品久久一区主播| 中文字幕亚洲天堂| 91精品国产色综合久久不卡98口| 国产日韩欧美中文| 国产成人av网址| 亚洲欧美综合精品久久成人| 国产在线观看不卡| 欧美理论片在线观看| 中文字幕视频一区二区在线有码| 高清一区二区三区日本久| 精品视频中文字幕| 欧美最猛性xxxx| 亚洲国产中文字幕久久网| 日韩中文字幕精品| 中文字幕日本精品| 亚洲精品国产福利| 亚洲国产毛片完整版| 成人免费视频xnxx.com| 日韩免费观看视频| 久久男人资源视频| 欧美性资源免费| 欧美精品少妇videofree| 国产精品盗摄久久久| 不卡av在线播放| 久久久久久亚洲精品中文字幕| 亚洲一区二区三区视频播放| 日本亚洲欧美成人| 日韩一区二区久久久| 日韩精品在线免费观看| 久久久久国产精品免费网站| 97免费在线视频| 2023亚洲男人天堂| 午夜欧美不卡精品aaaaa| 日韩久久午夜影院| www.欧美精品| 萌白酱国产一区二区| xxav国产精品美女主播| 中文字幕日韩在线播放| 国产噜噜噜噜久久久久久久久| 精品偷拍一区二区三区在线看| 亚洲人成电影网站色www| 亚洲欧洲中文天堂| 欧美激情一区二区三区高清视频| 成人深夜直播免费观看| 亚洲高清一区二| 亚洲欧洲激情在线| 亚洲欧美中文日韩在线| 国产精品日韩电影| 国产精品av免费在线观看| 91精品综合久久久久久五月天| 91在线国产电影| 91天堂在线视频| 日韩av免费观影| 久久99精品久久久久久青青91| 亚洲人成伊人成综合网久久久| 国产精品日本精品| 欧美电影在线观看网站| 亚洲精品综合久久中文字幕| 国产成人精品日本亚洲专区61| 在线观看国产精品91| 久久久精品影院| 亚洲精品美女免费| 欧美成年人在线观看| 国产一区欧美二区三区| 久久久亚洲福利精品午夜| 欧美人在线视频| 亚洲影院色在线观看免费| 91精品国产综合久久男男| 青青a在线精品免费观看| 成人黄色大片在线免费观看| 最新国产精品亚洲| 中文字幕日韩精品在线观看| 国产日本欧美一区| 日韩免费观看高清| 国产999视频| 国产成人一区二区三区电影| 成人深夜直播免费观看| 欧美丰满老妇厨房牲生活| 久久视频在线播放| 久久婷婷国产麻豆91天堂| 成人激情视频网| 国内精品一区二区三区四区| 欧美精品999| 九九精品在线播放| 91日本视频在线| 欧美激情视频免费观看| 中日韩美女免费视频网站在线观看| 亚洲国产成人久久综合| 久久久精品久久久久| 91日本在线视频| 51精品国产黑色丝袜高跟鞋| 欧洲日本亚洲国产区| 少妇高潮 亚洲精品| 亚洲精品白浆高清久久久久久| 伊人亚洲福利一区二区三区| 少妇高潮 亚洲精品| 久久综合电影一区| 国产精品444| 日韩欧中文字幕| 日韩在线观看免费全集电视剧网站| 亚洲成色777777女色窝| 不卡av电影院| 国产欧美日韩中文|