Springboot 整合 xxl-job
前言
很久很久以前写过好几篇关于定时任务的使用系列的文章:
这一篇是最简单的,就是单纯跑跑定时任务,那你看这篇就行,没必要用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的更多相关文章
- springboot整合xxl-mq学习笔记
首先xxl-mq是大神xuxueli开发的一个消息中间件框架: 与springboot整合过程: <?xml version="1.0" encoding="UTF ...
- springboot整合xxl-job分布式定时任务【图文完整版】
一.前言 定时任务有很多种,有一些大的框架也有一些简单的实现. 比如常见的: JDK的Timer和TimerTask Quartz异步任务调度框架 分布式定时任务XXL-JOB Spring Task ...
- spring-boot整合mybatis(1)
sprig-boot是一个微服务架构,加快了spring工程快速开发,以及简便了配置.接下来开始spring-boot与mybatis的整合. 1.创建一个maven工程命名为spring-boot- ...
- SpringBoot整合Mybatis之项目结构、数据源
已经有好些日子没有总结了,不是变懒了,而是我一直在奋力学习springboot的路上,现在也算是完成了第一阶段的学习,今天给各位总结总结. 之前在网上找过不少关于springboot的教程,都是一些比 ...
- springboot整合mq接收消息队列
继上篇springboot整合mq发送消息队列 本篇主要在上篇基础上进行activiemq消息队列的接收springboot整合mq发送消息队列 第一步:新建marven项目,配置pom文件 < ...
- springboot整合mybaits注解开发
springboot整合mybaits注解开发时,返回json或者map对象时,如果一个字段的value为空,需要更改springboot的配置文件 mybatis: configuration: c ...
- SpringBoot整合Redis、ApachSolr和SpringSession
SpringBoot整合Redis.ApachSolr和SpringSession 一.简介 SpringBoot自从问世以来,以其方便的配置受到了广大开发者的青睐.它提供了各种starter简化很多 ...
- SpringBoot整合ElasticSearch实现多版本的兼容
前言 在上一篇学习SpringBoot中,整合了Mybatis.Druid和PageHelper并实现了多数据源的操作.本篇主要是介绍和使用目前最火的搜索引擎ElastiSearch,并和Spring ...
- SpringBoot整合Kafka和Storm
前言 本篇文章主要介绍的是SpringBoot整合kafka和storm以及在这过程遇到的一些问题和解决方案. kafka和storm的相关知识 如果你对kafka和storm熟悉的话,这一段可以直接 ...
- SpringBoot整合SpringCloud搭建分布式应用
什么是SpringCloud? SpringCloud是一个分布式的整体解决方案.SpringCloud为开发者提供了在分布式系统中快速构建的工具,使用SpringCloud可以快速的启动服务或构建应 ...
随机推荐
- centos7-arm架构yum源(armhf) yum源(中国科学技术大学)
# CentOS-Base.repo # # The mirror system uses the connecting IP address of the client and the # upda ...
- java之封装日期工具类DateUtils
整合日期工具类DateUtils dateUtils日期工具类封装-各类格式方法 pom文件引入 <dependency> <groupId>cn.hutool</gro ...
- delphi Image32 路径
用 Image32的理由之一,也是路径这块做得比delphi(FMX)自带的要好,skia中支持svg,但对路径处理功能不够强大.VCL只能使用第三方库. VCL如果要支持SVG,只有 Image32 ...
- php 版本升级后需要对代码进行兼容性检测
来到需要检测代码的目录下 需要提前安装 docker 执行 docker run --rm -v $(pwd):/app vfac/php7compatibility 7.3 . --ignore=v ...
- Converter Tutorial
Setting up a simple example This is the most basic converter... let's start with a simple Person: pa ...
- 反编译工具之Jadx
jadx 是一款功能强大的反编译工具,使用起来简单方便(拖拽式操作),不光提供了命令行程序,还提供了 GUI 程序.一般情况下,我们直接使用 GUI 程序就可以了. jadx 支持 Windows.L ...
- go get 和 go install 对比
(一)命令定义和区别 go install 和 go get 都是 Go 语言的工具命令,但它们之间有一些区别. go get:用于从远程代码存储库(如 GitHub)中下载或更新 Go 代码包.它会 ...
- Xdebug+Phpstorm远程调试
开发环境: 本地 Windows10 日常开发使用的环境 装有PHPStorm 远程主机 Linux 服务器 装php-fpm/nginx等所有开发依赖环境 本地可以访问远程主机 但远程主机无法访问本 ...
- Natasha v9.0 为 .NET 开发者提供 [热执行] 方案.
项目简介 自 Natasha v9.0 发布起,我将基于 Natasha 的推出热执行方案,这项技术允许基于 控制台(Console) 和新版 Asp.net Core 架构的项目在运行中动态重编译, ...
- Vue项目“TypeError: Cannot read property ‘_wrapper’ of undefined
前情 最近在开发一个H5营销活动项目,为了更高的开发效率我使用了Vue全家桶来实现. 坑位 在开发中遇到一个奇怪报错(报错截图如下),从提示看也定位不到是哪里出问题 Why? 在报错的页面仔细看了一遍 ...