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 写到一个任务里)

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

相关推荐
通信小呆呆5 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
H__Rick5 天前
自动对焦学习-3
人工智能·学习·计算机视觉
Daisy Lee5 天前
量化学习-第1章-什么是量化金融
学习·金融·datawhale
Alsn865 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
YM52e5 天前
买菜计算器小应用 - HarmonyOS ArkUI 开发实战-PC版本
学习·华为·harmonyos·鸿蒙·鸿蒙系统
小雨下雨的雨5 天前
HarmonyOS ArkUI训练营入门-组件掌握系列-Animation 动画效果实现-PC版本
学习·华为·harmonyos·鸿蒙
cqbzcsq5 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
YangYang9YangYan5 天前
2026初入职场学习数据分析的价值
学习·数据挖掘·数据分析
guslegend5 天前
理论学习:什么是 Coding Agent?
学习
自传.5 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding