Today's topic: XXL job distributed scheduled tasks
reference resources: https://blog.csdn.net/huangjinjin520/article/details/106880276/
XXL-JOB is a lightweight distributed task scheduling framework. Its core design goal is rapid development, simple learning, lightweight and easy to expand. General microservices use this framework for scheduled tasks.
It happened that this thing was used in the company's new project, and then I was given the technical choice of the distributed scheduled task, including integrating this technology into the project. Today, let's record how to integrate it.
1 download XXL job
First, we need to download the project
git clone https://github.com/xuxueli/xxl-job.git
After downloading these modules, you can directly start the admin module to enter the background
xxl-job-admin: Dispatching center xxl-job-core: Public dependence xxl-job-executor: Actuator Sample Example (select the appropriate version of actuator, which can be used directly, or refer to it and transform the existing project into an actuator) xxl-job-executor-sample-spring: Spring Version, via Spring Container management actuator, which is more general, is recommended; xxl-job-executor-sample-springboot: Springboot Version, via Springboot Management actuator; xxl-job-executor-sample-jfinal: JFinal Version, via JFinal Management actuator; xxl-job-executor-sample-nutz: Nutz Version, via Nutz Management actuator;
data:image/s3,"s3://crabby-images/c099a/c099a5c95af9e247d5301519ea0ac94e11441ca3" alt=""
I'll just choose the spring boot actuator
2 import script
Type the script in the doc directory into the database
data:image/s3,"s3://crabby-images/dd2e5/dd2e5eb99373b5822883c0eb8b667b504e155265" alt=""
3. Modify database account and password
data:image/s3,"s3://crabby-images/2f26c/2f26cc980d53a8d16ecf890eb5436066cf2f0bdd" alt=""
Insert picture description here
4. Add Scheduled Task business class
data:image/s3,"s3://crabby-images/f76cd/f76cd8d8abfb027d55cfc0351c739d16cdac550c" alt=""
Insert picture description here
5. The actuator name shall correspond to
data:image/s3,"s3://crabby-images/2bdf0/2bdf0a94ff2631801de68419d0c19d33a3d49843" alt=""
Add corresponding actuator management in actuator management
data:image/s3,"s3://crabby-images/ee730/ee7305ddca627a80246388828c1a7bc16ab0f505" alt=""
The machine address can be registered automatically without writing.
data:image/s3,"s3://crabby-images/75ea6/75ea652037a04d582d08b4d03395d670f1f39877" alt=""
If there is no actuator, add an actuator
data:image/s3,"s3://crabby-images/74b3f/74b3f0d6d46eaa9a02c75c1f4a062fc20aa5579a" alt=""
6 add scheduled tasks
Add scheduled task
data:image/s3,"s3://crabby-images/c10e0/c10e0bc18bc045ab2d7a222f30080dc0b5f8e229" alt=""
data:image/s3,"s3://crabby-images/42ecd/42ecd72cc0f4923d44a1a41eb6e1f8be6d9f530b" alt=""
Execute it and find that it can succeed.
data:image/s3,"s3://crabby-images/a30ad/a30ad25a04d28a22d972bb9b3a4826c0174ac612" alt=""
data:image/s3,"s3://crabby-images/64d48/64d4888c91437c6da3e537ad4ece6a6ec959bd4a" alt=""
OK, this completes the simple startup.
7 integration in the project
The official XXL job executor sample jboot is actually a module in our microservice, so we can introduce dependencies in our own projects:
<!--xxj-job Core dependency--> <dependency> <groupId>com.xuxueli</groupId> <artifactId>xxl-job-core</artifactId> <version>2.3.0</version> </dependency>
In fact, I can create a public module of XXL job and create a configuration class:
data:image/s3,"s3://crabby-images/b8908/b89086da46aa80e619e70eeff6bf784889604590" alt=""
public class XxlJobConfig { private Logger logger = LoggerFactory.getLogger(XxlJobConfig.class); @Value("${xxl.job.addresses}") private String adminAddresses; @Value("${xxl.job.accessToken}") private String accessToken; @Value("${xxl.job.appname}") private String appname; @Value("${xxl.job.address}") private String address; @Value("${xxl.job.ip}") private String ip; @Value("${xxl.job.port}") private int port; @Value("${xxl.job.logpath}") private String logPath; @Value("${xxl.job.logretentiondays}") private int logRetentionDays; @Bean public XxlJobSpringExecutor xxlJobExecutor() { logger.info(">>>>>>>>>>> xxl-job config init."); XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor(); xxlJobSpringExecutor.setAdminAddresses(adminAddresses); xxlJobSpringExecutor.setAppname(appname); xxlJobSpringExecutor.setAddress(address); xxlJobSpringExecutor.setIp(ip); //Offset 1000 ports to the right based on the project ports, which can be compatible with the projects of all modules xxlJobSpringExecutor.setPort(port+1000); xxlJobSpringExecutor.setAccessToken(accessToken); xxlJobSpringExecutor.setLogPath(logPath); xxlJobSpringExecutor.setLogRetentionDays(logRetentionDays); return xxlJobSpringExecutor; } /** * For multiple network cards and internal deployment of containers, the registered IP can be flexibly customized with the help of the "InetUtils" component provided by "spring cloud commons"; * * 1,Import dependency: * <dependency> * <groupId>org.springframework.cloud</groupId> * <artifactId>spring-cloud-commons</artifactId> * <version>${version}</version> * </dependency> * * 2,Configuration file, or container startup variable * spring.cloud.inetutils.preferred-networks: 'xxx.xxx.xxx.' * * 3,Get IP * String ip_ = inetUtils.findFirstNonLoopbackHostInfo().getIpAddress(); */ }
data:image/s3,"s3://crabby-images/1061b/1061babe393fd3722d9de95d86594084fe6486e9" alt=""
Introduce dependencies in this module:
<!--xxj-job Core dependency--> <dependency> <groupId>com.xuxueli</groupId> <artifactId>xxl-job-core</artifactId> <version>2.3.0</version> </dependency>
Then we can introduce the XXL job module into our own module
data:image/s3,"s3://crabby-images/54aa1/54aa175bd747fbc31f2ca6ca2a445b10ee59dc6e" alt=""
Just create a task class, introduce @ XXL job, configure a Handler, and add it in the background.
data:image/s3,"s3://crabby-images/3c597/3c597923b5e596efc9eb1f7cefaf622afc6d12a1" alt=""
nacos configuration:
# xxl-job logging: config: classpath:logback.xml xxl: job: accessToken: "" addresses: http://127.0.0.1:9207/xxl-job-admin address: "" appname: ${spring.application.name} ip: "" logpath: /data/applogs/xxl-job/jobhandler logretentiondays: 30 port: ${server.port}
That is, on the official website document of XXL job, we only need the admin module.