侧边栏壁纸
  • 累计撰写 106 篇文章
  • 累计创建 19 个标签
  • 累计收到 1 条评论

目 录CONTENT

文章目录

比XXL-JOB更好用,更强大的分布式任务调度中间件

zero
2023-07-21 / 0 评论 / 2 点赞 / 50 阅读 / 6345 字
温馨提示:
本文最后更新于 2024-07-07,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

前言

PowerJob是新一代分布式任务调度与计算框架,支持CRON、API、固定频率、固定延迟等调度策略,提供工作流来编排任务解决依赖关系,能让您轻松完成作业的调度与繁杂任务的分布式计算。

主要特性

  • 使用简单:提供前端 Web 界面,允许开发者可视化地完成调度任务的管理(增、删、改、查)、任务运行状态监控和运行日志查看等功能。

  • 定时策略完善:支持 CRON 表达式、固定频率、固定延迟和 API 四种定时调度策略。

  • 执行模式丰富:支持单机、广播、Map、MapReduce 四种执行模式,其中 Map/MapReduce 处理器能使开发者寥寥数行代码便获得集群分布式计算的能力。

  • DAG 工作流支持:支持在线配置任务依赖关系,可视化得对任务进行编排,同时还支持上下游任务间的数据传递

  • 执行器支持广泛:支持 Spring Bean、内置 / 外置 Java 类、Shell、Python 等处理器,应用范围广。

  • 运维便捷:支持在线日志功能,执行器产生的日志可以在前端控制台页面实时显示,降低 debug 成本,极大地提高开发效率。

  • 依赖精简:最小仅依赖关系型数据库(MySQL/Oracle/MS SQLServer...),扩展依赖为 MongoDB(用于存储庞大的在线日志)。

  • 高可用 & 高性能:调度服务器经过精心设计,一改其他调度框架基于数据库锁的策略,实现了无锁化调度。部署多个调度服务器可以同时实现高可用和性能的提升(支持无限的水平扩展)。

  • 故障转移与恢复:任务执行失败后,可根据配置的重试策略完成重试,只要执行器集群有足够的计算节点,任务就能顺利完成。

适用场景

  • 有定时执行需求的业务场景:如每天凌晨全量同步数据、生成业务报表等。

  • 有需要全部机器一同执行的业务场景:如使用广播执行模式清理集群日志。

  • 有需要分布式处理的业务场景:比如需要更新一大批数据,单机执行耗时非常长,可以使用 Map/MapReduce 处理器完成任务的分发,调动整个集群加速计算。

  • 有需要延迟执行某些任务的业务场景:比如订单过期处理等。

设计目标

PowerJob 的设计目标为企业级的分布式任务调度平台,即成为公司内部的任务调度中间件。整个公司统一部署调度中心 powerjob-server,旗下所有业务线应用只需要依赖 powerjob-worker 即可接入调度中心获取任务调度与分布式计算能力。

同类产品对比

 

QuartZ

xxl-job

SchedulerX 2.0

PowerJob

定时类型

CRON

CRON

CRON、固定频率、固定延迟、OpenAPI

CRON、固定频率、固定延迟、OpenAPI

任务类型

内置 Java

内置 Java、GLUE Java、Shell、Python 等脚本

内置 Java、外置 Java(FatJar)、Shell、Python 等脚本

内置 Java、外置 Java(容器)、Shell、Python 等脚本

分布式任务

静态分片

MapReduce 动态分片

MapReduce 动态分片

在线任务治理

不支持

支持

支持

支持

日志白屏化

不支持

支持

不支持

支持

调度方式及性能

基于数据库锁,有性能瓶颈

基于数据库锁,有性能瓶颈

不详

无锁化设计,性能强劲无上限

报警监控

邮件

短信

邮件,提供接口允许开发者扩展

系统依赖

JDBC 支持的关系型数据库(MySQL、Oracle...)

MySQL

人民币

任意 Spring Data Jpa 支持的关系型数据库(MySQL、Oracle...)

DAG 工作流

不支持

不支持

支持

支持

官方文档

中文文档

Document

2

评论区