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中的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 任务调度中心 —— 任务管理—— 新增任务,例如: