专栏首页凯哥JavaJava任务调度框架之分布式调度框架XXL-Job介绍
原创

Java任务调度框架之分布式调度框架XXL-Job介绍

Java任务调度框架之分布式调度框架XXL-Job介绍及快速入门

调度器使用场景:

Java开发中经常会使用到定时任务:比如每月1号凌晨生成上个月的账单、比如每天凌晨1点对上一天的数据进行对账操作,在比如每天凌晨5点给180天未登陆过的用户发送邮件提醒等等。定时任务在我们开发中也占有很重要的部分。

Java实现定时任务有很多方式:

1.JDK自带的定时器实现,即java.util.TimerTask类

2.使用Quartz定时器来实现

3.使用spring相关的任务调度。自spring 3.0+以后,spring自带的任务调度,主要依靠TaskScheduler接口的十几个实现来来实现的

4.spring结合quartz实现的

5.配合linux的crontabe来实现

等等其他的。

在这里凯哥介绍一个分布式任务调度框架-XXL-Job。作者:许雪里。代码现在已经开源了。

xxl-job介绍:

先来看下目前最新版本v2.1.0的架构图:

再来看看在git上的stars:

再来看下xxl-job的发展:

我们先来看看官方介绍:

XXL-JOB是一个分布式任务调度平台,其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线,开箱即用。

快速入门

源码下载:

在git上下载源码(因平台限制,凯哥就不贴git地址了),使用到的git命令:git clone。

下载后,将代码导入到idea中。

环境要求:

Maven 3+

jdk1.7+

mysql5.7+

先来看看项目结构:

初始化sql脚本

在/xxl-job/doc/db/tables_xxl_job.sql是sql脚本文件。

sql初始化错误解决

在sql脚本导入的时候,有可能会遇到如下错误:

可以参考如下文章进行修改:

sql脚本执行之后,可以看到有以下6张表了。

任务调度中心的配置

在XXL-Job所有项目中,任务调度中心就是源码中的xxl-job-admin这个工程。我们需要修改这个工程中信息成为自己的。

修改admin配置文件

文件地址:/xxl-job/xxl-job-admin/src/main/resources/xxl-job-admin.properties

1:修改数据库信息

2:如果需要邮件的话可以配置成自己的。其他项根据需求进行修改即可

部署调度中心项目

因为admin项目是spring boot项目,所以,我们直接run:XxlJobAdminApplication即可。文件位置如下图:

启动项目后,在浏览器中输入:127.0.0.1:8080/xxl-job-admin

默认的用户名及密码->用户名:admin 密码:123456

登陆之后,出现如下图的界面:

菜单说明:

运行报表:如上图。是调度器运行情况报表

任务管理:定时任务管理列表

调度日志:运行日志记录

执行器管理:

​本文来源:凯哥Java(kaigejava)

先配置执行器,然后在任务管理中,新增任务管理,启动任务之后,就可以在调度日志中,查看到运行结果了。

在下一篇中,我们将介绍怎么在spring boot项目中集成xxl-job使用教程。欢迎大家一起学习。

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 开源框架分布式任务调度xxl-job

    XXL-JOB是一个分布式任务调度平台,其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线,开箱即用

    疯狂的KK
  • 分布式定时任务调度框架之elastic-job简介

    lyb-geek
  • micro-job分布式任务调度框架更新

    micro-job是一款分布式任务调度执行框架,内部通过各个组件的Jersey共享出的Rest路径进行数据访问。

    恒宇少年
  • 任务调度-分布式任务调度平台XXL-JOB

    如果上述二种方式都不满足你的需求,我建议你尝试使用XXL-JOB或其他开源调度平台。

    秋日芒草
  • 分布式任务调度平台XXL-JOB

    XXL-JOB是一个轻量级分布式任务调度框架,其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线,开箱即用。

    用户1518699
  • 分布式任务调度平台XXL-JOB

    任务调度是指基于给定的时间点,给定的时间间隔又或者给定执行次数自动的执行任务。我们可以思考一下在以下场景中,我们应该怎么实现:

    我没有三颗心脏
  • 三千字带你搞懂XXL-JOB任务调度平台

    所以定时任务在平时开发中并不少见,而且对于现在快速消费的时代,每天都需要发送各种推送,消息都需要依赖定时任务去完成,应用非常广泛。

    java技术爱好者
  • XXL-JOB使用笔记

    itliusir
  • 笑话:大厂都在用的任务调度框架我能不知道吗???

    我之前的工作中一直在用 Elastic-Job 来做任务调度。这也是大家为什么能在我的书籍《Spring Cloud 微服务 入门 实战与进阶》中看到 Elas...

    猿天地

扫码关注云+社区

领取腾讯云代金券