前言


很久很久以前写过好几篇关于定时任务的使用系列的文章:

这一篇是最简单的,就是单纯跑跑定时任务,那你看这篇就行,没必要用xxljob(因为xxljob要跑服务端,然后自己服务作为客户端接入):

文章 使用@Scheduled 简单实现定时任务

然后这一篇是开始打开封装的壳子,开始可以自己手动配置地去使用定时任务了:

文章 使用Quartz定时器执行多个定时任务 配置篇

然后再继续打开封装的壳子,可以更加自由地去使用定时任务,也就是动态调度:

文章 Quartz定时任务的动态调度使用,实战详解

今天,带来的xxljob的使用, 可能很多人已经会用(最近挺多应届生问到这个的使用),所以我还是选择写一下整合xxl job 的使用入门篇。

正文


在什么都没开始的时候,我们看看springboot 使用 xxljob,需要有些什么,简图:

admin :理解为 server服务端 ,负责提供xxljob相关功能

demo: 理解为 client客户端,你自己想用xxljob的服务

HTML页面, 可视化操作,任务调度。

demo负责通过代码叙述自己的定时任务要做的东西, admin管不着。

admin管什么,可以管 这些任务怎么执行,怎样执行。怎么管? 在HTML页面上管 (其实也有api方式,该篇不讲)。

看到这里,新手的看客是否觉得好麻烦,又要写server端代码,又要接入,而且还得写前端HTML页面?

啥玩意,不搞了。 (是的,正常要是这样的话我也不搞)

如果说这一切都是开箱即用,这样你觉得可以接受吗?

代码GITEE地址(不是我写的,xuxueli 都全部写好了,我之所以这么引出来,是怕你们只能接受我,接受不了别人) :

https://gitee.com/xuxueli0323/xxl-job

下载代码解压出来:

IDEA上打开项目:

开始实战应用:

先创建数据库 (sql 是现成的)

执行完:

一.把admin 服务端跑起来

application.properties文件,注意红色框的几个地方(端口我自己改了个自己喜欢的8961,大家随意就行)改完直接运行:

然后去HTML管理界面看下,http://localhost:8961/xxl-job-admin

默认账号 admin

默认密码 123456

PS: 如果你忘记密码了怎么办?

跑偏了,继续,登录成功可以进到任务调度中心界面:

到这,先不用管其他的,我们接下来第二步。

二.接入xxljob,开始使用xxljob实现定时任务

红色框的这几个点,比较重要:

既然要接如xxl job ,那么 admin 的接入地址,肯定是要对应的:

xxl.job.admin.addresses=http://127.0.0.1:8961/xxl-job-admin

executor 至关重要, 这个就是 任务执行器, 每个job任务都是需要执行器来执行的,就像子弹和枪的关系 。

这个executor ,简单的理解为每个接入的demo服务对应一个就行。

这个可视化界面是随时可以新增、删除、修改的, 但是怎么操作得对应起来才能正常运行。

当然了,直接改数据库表数据也行:

PS: 如果我不想某个任务执行了, 那么把相关得执行器干掉就行。

子弹没有对应型号的枪,能打吗?

改完配置,就已经接入成功了其实。

怎么使用?

 

示例代码:

/**

* 示例

*/

@XxlJob("clockInJobHandler")

public void clockInJobHandler() throws Exception {

logger.info("clockInJobHandler 正在执行打卡校验" + new Date());

}

然后把demo 跑起来 ,

控制台的日志可以看到,好多个任务已经都注册到admin去了 :

代码都写好了, 那么就是 在HTML页面 操作调度一下就可以。

新增对任务的管理 :

任务启动了:

可以看到控制台,定时任务在定时执行:

好了该篇就到这吧, 总结一下springboot 快速整合 xxl-job 需要做的事情:

1. 下载开源的代码

2.用开源提供的sql创建数据库

3.改下admin的配置文件,运行项目

4.改下自己服务的配置文件,接入xxl -job

5.用注解@XxlJob 写下定时任务实现的代码

6.去HTML管理界面,创建一下 执行器、任务器

1.xxjob环境配置
1.1源码下载
xxjob源码下载传送门

1.2初始化数据库
在xxl-job-2.0.1\doc\db\tables_xxl_job.sql执行这个sql文件到

1.3项目中配置数据源

1.3启动项目
登录http://localhost:8080/xxl-job-admin/jobinfo 配置成功

2.项目中引入xxjob
2.1导入xxjob依赖
<!-- xxl-job-core -->

<dependency>
<groupId>com.xuxueli</groupId>
<artifactId>xxl-job-core</artifactId>
<version>2.0.1</version>
</dependency>
1
2
3
4
5
6
7
2.1application.yaml中配置
xxl-job:
#xxjob的地址
address: 127.0.0.1:8888/xxl-job-admin/
#执行器的名字
executor-appname: xx-job-ext
#注册的地址 自动注入可以不写
executor-ip:
executor-port: 8081
accessToken:
executor-logpath: D:/tmp
executor-logretentionday: 1
1
2
3
4
5
6
7
8
9
10
11
package com.zrp.config;

import com.xxl.job.core.executor.impl.XxlJobSpringExecutor;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
* @author 赵锐鹏
* @date 2021/11/3 0003
*/
@Configuration
public class XxJobConfig {
@Value("${xxl-job.address}")
private String adminAddresses;

@Value("${xxl-job.executor-appname}")
private String appName;

@Value("${xxl-job.executor-ip}")
private String ip;

@Value("${xxl-job.executor-port}")
private int port;

@Value("${xxl-job.accessToken}")
private String accessToken;

@Value("${xxl-job.executor-logpath}")
private String logPath;

@Value("${xxl-job.executor-logretentionday}")
private int logRetentionDays;

@Bean(initMethod = "start", destroyMethod = "destroy")
public XxlJobSpringExecutor xxlJobExecutor() {
XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor();
xxlJobSpringExecutor.setAdminAddresses(adminAddresses);
xxlJobSpringExecutor.setAppName(appName);
xxlJobSpringExecutor.setIp(ip);
xxlJobSpringExecutor.setPort(port);
xxlJobSpringExecutor.setAccessToken(accessToken);
xxlJobSpringExecutor.setLogPath(logPath);
xxlJobSpringExecutor.setLogRetentionDays(logRetentionDays);
return xxlJobSpringExecutor;

}
}

Springboot 整合 xxl-job的更多相关文章

  1. springboot整合xxl-mq学习笔记

    首先xxl-mq是大神xuxueli开发的一个消息中间件框架: 与springboot整合过程: <?xml version="1.0" encoding="UTF ...

  2. springboot整合xxl-job分布式定时任务【图文完整版】

    一.前言 定时任务有很多种,有一些大的框架也有一些简单的实现. 比如常见的: JDK的Timer和TimerTask Quartz异步任务调度框架 分布式定时任务XXL-JOB Spring Task ...

  3. spring-boot整合mybatis(1)

    sprig-boot是一个微服务架构,加快了spring工程快速开发,以及简便了配置.接下来开始spring-boot与mybatis的整合. 1.创建一个maven工程命名为spring-boot- ...

  4. SpringBoot整合Mybatis之项目结构、数据源

    已经有好些日子没有总结了,不是变懒了,而是我一直在奋力学习springboot的路上,现在也算是完成了第一阶段的学习,今天给各位总结总结. 之前在网上找过不少关于springboot的教程,都是一些比 ...

  5. springboot整合mq接收消息队列

    继上篇springboot整合mq发送消息队列 本篇主要在上篇基础上进行activiemq消息队列的接收springboot整合mq发送消息队列 第一步:新建marven项目,配置pom文件 < ...

  6. springboot整合mybaits注解开发

    springboot整合mybaits注解开发时,返回json或者map对象时,如果一个字段的value为空,需要更改springboot的配置文件 mybatis: configuration: c ...

  7. SpringBoot整合Redis、ApachSolr和SpringSession

    SpringBoot整合Redis.ApachSolr和SpringSession 一.简介 SpringBoot自从问世以来,以其方便的配置受到了广大开发者的青睐.它提供了各种starter简化很多 ...

  8. SpringBoot整合ElasticSearch实现多版本的兼容

    前言 在上一篇学习SpringBoot中,整合了Mybatis.Druid和PageHelper并实现了多数据源的操作.本篇主要是介绍和使用目前最火的搜索引擎ElastiSearch,并和Spring ...

  9. SpringBoot整合Kafka和Storm

    前言 本篇文章主要介绍的是SpringBoot整合kafka和storm以及在这过程遇到的一些问题和解决方案. kafka和storm的相关知识 如果你对kafka和storm熟悉的话,这一段可以直接 ...

  10. SpringBoot整合SpringCloud搭建分布式应用

    什么是SpringCloud? SpringCloud是一个分布式的整体解决方案.SpringCloud为开发者提供了在分布式系统中快速构建的工具,使用SpringCloud可以快速的启动服务或构建应 ...

随机推荐

  1. Python 潮流周刊#75:用 Python 开发 NoSQL 数据库(摘要)

    本周刊由 Python猫 出品,精心筛选国内外的 250+ 信息源,为你挑选最值得分享的文章.教程.开源项目.软件工具.播客和视频.热门话题等内容.愿景:帮助所有读者精进 Python 技术,并增长职 ...

  2. 2.5 使用U盘安装Linux系统

    前面章节介绍了如何通过虚拟机 VMware 安装 Linux 系统,而实际开发中,我们更多的是要将 Linux 系统直接安装到电脑上. 直接在电脑上安装 Linux 系统的常用方法有 2 种,分别是用 ...

  3. 2-2 C++变量

    目录 2.2.1 变量定义:列表初始化(list initialization) 2.2.2 变量的定义与声明 C++分离式编译 定义与声明 2.2.3 C++变量命名 2.2.4 变量名的作用域(s ...

  4. 5.jenkins的项目构建

    Jenkins构建的项目类型介绍 Jenkins中自动构建项目的类型有很多,常用的有以下三种 自由风格软件项目(FreeStyle Project) Maven项目(Maven Project) 流水 ...

  5. 深入Log4J源码之Log4J Core

    毕业又赶上本科的同学会,还去骑车环了趟崇明岛,六月貌似就没消停过,不过终于这些事情基本上都结束了,我也可以好好的看些书.读些源码.写点博客了. Log4J将写日志功能抽象成七个核心类/接口:Logge ...

  6. golang之json.RawMessage

    RawMessage 具体来讲是 json 库中定义的一个类型.它实现了 Marshaler 接口以及 Unmarshaler 接口,以此来支持序列化的能力.注意上面我们引用 官方 doc 的说明. ...

  7. golang之异步队列Asynq

    Asynq[1]是一个Go实现的分布式任务队列和异步处理库,基于redis,类似Ruby的sidekiq[2]和Python的celery[3].Go生态类似的还有machinery[4]和gowor ...

  8. 【CSS样式】好看的样式千篇一律,有趣的灵魂万里挑一

    input 输入框美化: https://www.jianshu.com/p/9b4b60b8d475 button 按钮美化: 1.登录框按钮 https://blog.csdn.net/wangj ...

  9. OceanBase 的探索与实践

    作者:来自 vivo 互联网数据库团队- Xu Shaohui 本文总结了目前我们遇到的痛点问题并通过 OceanBase 的技术方案解决了这些痛点问题,完整的描述了 OceanBase 的实施落地, ...

  10. PDFsharp 1.50

    PDFsharp 1.50 Preview Information - PDFsharp & MigraDoc PDFShapr 1.50 修复与改进 支持 Object Streams - ...