xxl-job分布式任务调度

(1)、关于xxl-job 需要了解的

xxl-job 分布式任务调度
什么是xxl-job?
XXL-JOB是美团点评开源的轻量级分布式任务调度平台,它是比较受欢迎的国产开源软件之一。

在linux上安装xxl-job
部署思路:
获取xxl-job源码包
对源码包进行maven编译,获取"可运行的jar包"
使用java 运行编译后的jar包
使用:
在xxl-job-admin里配置"执行管理器"

(2)、在linux上部署xxl-job

前提条件
安装过java和maven环境

开始部署:
1.获取源码包
https://github.com/xuxueli/xxl-job/archive/refs/tags/2.3.0.tar.gz
并将程序文件解压包到 /usr/local/xxl-job-2.3.0/

2.创建xxl-job数据库
使用源码包文件 xxl-job-2.3.0/doc/db/tables_xxl_job.sql 来创建xxl-job数据库, 数据库类型为mysql,
数据库名为xxl_job 数据库用户名和密码使用mysql root账户。

3.修改xxl-job-admin
编辑 vim /usr/local/xxl-job-2.3.0/xxl-job-admin/src/main/resources/application.properties
需要修改或注意的地方有:

1
2
3
4
5
6
server.port=8666
   server.servlet.context-path=/xxl-job-admin
   spring.datasource.url=jdbc:mysql://127.0.0.1:3306/xxl_job?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghai
   spring.datasource.username=root
   spring.datasource.password=password
   spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

4.打包xxl-job项目
cd /usr/local/xxl-job-2.3.0
mvn package

打包完成后,生成的可运行的jar包文件路径如下:

1
2
3
4
./xxl-job-admin/target/xxl-job-admin-2.3.0.jar
  ./xxl-job-core/target/xxl-job-core-2.3.0.jar
  ./xxl-job-executor-samples/xxl-job-executor-sample-frameless/target/xxl-job-executor-sample-frameless-2.3.0.jar
  ./xxl-job-executor-samples/xxl-job-executor-sample-springboot/target/xxl-job-executor-sample-springboot-2.3.0.jar

5. 启动xxl-job-admin
我们使用"xxl-job-admin-2.3.0.jar"来启动xxl-job-admin,启动脚本如下:
启动xxl-job
/usr/local/xxl-job-2.3.0/start.sh 脚本内容为

1
2
3
4
5
6
7
8
9
10
11
 #!/bin/sh
    var=`find . -name xxl-job-admin-2.3.0.jar`
    fname=${var}
    java  -jar -Xms512M -Xmx1024M -Xmn100M  ${fname} >>nohup.out 2>&1& echo $! > xxljob_service.pid

   停止xxl-job
      /usr/local/xxl-job-2.3.0/stop.sh 脚本内容
    #!/bin/sh
    pid=$(cat xxljob_service.pid)
    kill -9 $pid
    rm -rf xxljob_service.pid

6. 访问xxl-job服务
访问地址: http://ip:端口号/xxl-job-admin,默认用户名admin 默认密码为 123456
例如:http://173.16.200.91:8666/xxl-job-admin

(3)、使用xxl-job
1.创建执行器管理
xxl-job-admin 任务调度中心 ——执行器管理—— 新增一个执行器,这个地方的执行器的机器地址是项目应用app的地址。XXL-JOB执行器配置及定时任务的创建 <-点击此处可参考 https://blog.csdn.net/qq_38249409/article/details/127456979 xxl-job分布式任务调度
关于xxl-job中的cron表达式
秒数 分钟 小时 日期 月份 星期 年份(可为空)}
*/5 * * * * ?
各个位置的取值范围

1
2
3
4
5
6
7
8
9
秒 0-59 , - * /
    分 0-59 , - * /
    小时 0-23 , - * /
    日期 1-31 , - * ? / L W C
    月份 1-12 或者 JAN-DEC , - * / 可以用0-11 或用字符串 “JAN, FEB, MAR, APR, MAY,
    JUN, JUL, AUG, SEP, OCT, NOV and DEC” 表示
    星期 1-7 或者 SUN-SAT , - * ? / L C # 可以用数字1-7表示(1 = 星期日)或用字符口串“SUN, MON,
    TUE, WED, THU, FRI and SAT”表示
    年(可选) 留空, 1970-2099 , - * /

上述取值范围中的符号详解

1
2
3
4
5
  * 表示所有值;  
    ? 表示未说明的值,即不关心它为何值;
    - 表示一个指定的范围;  
    , 表示附加一个可能值;
    / 符号前表示开始时间,符号后表示每次递增的值;

下面是一些表达式的案例和cron表达式生成器地址

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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
*/5 * * * * ? 每隔5秒执行一次
0 */1 * * * ? 每隔1分钟执行一次
0 0 5-15 * * ? 每天5-15点整点触发
0 0/3 * * * ? 每三分钟触发一次
0 0-5 14 * * ? 在每天下午2点到下午2:05期间的每1分钟触发
0 0/5 14 * * ? 在每天下午2点到下午2:55期间的每5分钟触发
0 0/5 14,18 * * ? 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发
0 0/30 9-17 * * ? 朝九晚五工作时间内每半小时
0 0 10,14,16 * * ? 每天上午10点,下午2点,4点

0 0 12 ? * WED 表示每个星期三中午12点
0 0 17 ? * TUES,THUR,SAT 每周二、四、六下午五点
0 10,44 14 ? 3 WED 每年三月的星期三的下午2:10和2:44触发
0 15 10 ? * MON-FRI 周一至周五的上午10:15触发
0 0 23 L * ? 每月最后一天23点执行一次
0 15 10 L * ? 每月最后一日的上午10:15触发
0 15 10 ? * 6L 每月的最后一个星期五上午10:15触发
0 15 10 * * ? 2005 2005年的每天上午10:15触发
0 15 10 ? * 6L 2002-2005 2002年至2005年的每月的最后一个星期五上午10:15触发
0 15 10 ? * 6#3 每月的第三个星期五上午10:15触发

"30 * * * * ?" 每半分钟触发任务
"30 10 * * * ?" 每小时的10分30秒触发任务
"30 10 1 * * ?" 每天1点10分30秒触发任务
"30 10 1 20 * ?" 每月20号1点10分30秒触发任务
"30 10 1 20 10 ? *" 每年10月20号1点10分30秒触发任务
"30 10 1 20 10 ? 2011" 2011年10月20号1点10分30秒触发任务
"30 10 1 ? 10 * 2011" 2011年10月每天1点10分30秒触发任务
"30 10 1 ? 10 SUN 2011" 2011年10月每周日1点10分30秒触发任务
"15,30,45 * * * * ?" 每15秒,30秒,45秒时触发任务
"15-45 * * * * ?" 15到45秒内,每秒都触发任务
"15/5 * * * * ?" 每分钟的每15秒开始触发,每隔5秒触发一次
"15-30/5 * * * * ?" 每分钟的15秒到30秒之间开始触发,每隔5秒触发一次
"0 0/3 * * * ?" 每小时的第0分0秒开始,每三分钟触发一次
"0 15 10 ? * MON-FRI" 星期一到星期五的10点15分0秒触发任务
"0 15 10 L * ?" 每个月最后一天的10点15分0秒触发任务
"0 15 10 LW * ?" 每个月最后一个工作日的10点15分0秒触发任务
"0 15 10 ? * 5L" 每个月最后一个星期四的10点15分0秒触发任务
"0 15 10 ? * 5#3" 每个月第三周的星期四的10点15分0秒触发任务

2.创建任务
xxl-job-admin 任务调度中心 —— 任务管理—— 新增任务,例如:
xxl-job分布式任务调度
xxl-job分布式任务调度

相关新闻

联系我们

全国服务热线

400-033-9553

电子邮件:admin@example.com
工作时间:09:00-17:00 周一至周五

在线客服
关注微信
关注微信
分享本页
返回顶部