xxljob学习(大白话版本)

1)XXL-JOB里那三样东西

调度中心(xxl-job-admin):网页后台 + 任务配置的地方。它负责"按时/按需叫人干活"。

执行器(Executor):干活的人(你的 brain-api-job 容器)。它在 9999 端口等着被调度中心喊去干活。

任务(Job):一条"让执行器做什么"的配置记录(比如"跑报告生成")。

一句话:任务属于调度中心,干活在执行器里。

2)新增任务里常见参数的意思

  • 执行器(brain-api-job)
    选"把任务派给哪一类工人"(哪个服务来跑)
  • 运行模式:BEAN
    意思是"执行器里用Spring Bean的方式找 handler"(也就是用 @XxlJob("xxx") 这种)
    项目就是用这个,所以固定选它
  • 调度类型:CRON
    定时器,按生产环境具体配置。
  • 路由策略:第一个
    如果一个执行器下面未来会有多台机器在线(多实例),这个决定"派给哪台"
    现在你只有 1 台,所以选啥都一样;"第一个"最简单
  • 阻塞处理策略:单机串行
    如果上一次还没跑完,又来了一次触发,怎么办?
    "单机串行"=排队一个个来,不会同一台机器并发跑同一个任务(最稳妥)
  • 任务超时时间:0
    0 通常表示不单独设置超时
  • 失败重试次数:0
    失败不自动重试;学习阶段先 0,避免失败后反复刷日志

3)JobHandler

JobHandler 本质就是"函数名/入口名"

代码里就是这样写的:

@XxlJob("reportGenerateHandler")

@XxlJob("sessionPauseExpiredHandler")

4)点"执行一次"弹窗里,"任务参数"和"机器地址"填什么

机器地址=派给哪台机器干;任务参数=这次干活要带的口令/附加说明。

  • 机器地址
    选的是自动注册,一般不用自己填,它会从在线地址列表里挑一台(日志里就是 http://172.20.0.10:9999/)
    只有在"手动录入地址/固定某台机器"这种场景才需要选/填
  • 任务参数(JobParam/任务参数)
    就是一段字符串,调度中心会原样传给 handler
    只有handler 代码里读取了参数,这个才有用

我现在学习用的是报告生成 / 暂停超时,从代码看是"扫表处理",通常 不需要参数,所以留空就对了

5)生产环境(prod)应该怎么配"执行器和任务"?

① 执行器(分组/AppName)

生产也建一个执行器分组,AppName 一定要和代码里一致(默认就是 brain-api-job)

如果生产也跑一份 job 服务(通常会),它会自动注册地址(多台就会出现多个地址)

② 任务(Job)

把你需要的任务都建成记录(和dev一样),JobHandler 仍然填那段英文

生产差别主要在两点:

调度类型从 NONE 改为 CRON

路由策略如果有多台实例,建议用"轮询/一致性哈希/故障转移"等(先用"轮询"也行)

③ 一个关键原则

一个 JobHandler 对应一条任务配置(不要把两个 handler 写到一个任务里)

每条任务的"责任"越单一越好(出问题好定位)

相关推荐
吃好睡好便好1 小时前
说说免疫力的维护
学习·生活
凉、介2 小时前
深入理解 ARMv8-A|处理器模式与寄存器
笔记·学习·嵌入式·arm
z200509302 小时前
【linux学习】深入理解linux文件I/O,从C标准库到内核态
linux·学习·操作系统
阿文的代码库3 小时前
康威尔生命游戏规则介绍与学习
学习
我的xiaodoujiao3 小时前
API 接口自动化测试详细图文教程学习系列24--如何用Pytest去设计接口测试用例并执行
python·学习·测试工具·pytest
-To be number.wan3 小时前
计算机组成原理 | SRAM与DRAM
学习·计算机组成原理
朔北之忘 Clancy4 小时前
2026 年 3 月青少年软编等考 C 语言二级真题解析
c语言·开发语言·c++·学习·青少年编程·题解·考级
Upsy-Daisy5 小时前
IOTA 学习笔记(四):当前 IOTA 架构总览
笔记·学习·架构
小拉达不是臭老鼠5 小时前
Unity中的UI系统之UGUI
学习·ui·unity