**1. 任务暂停(挂起)**
```java
//方式1:只暂停该触发器绑定的任务实例
scheduler.pauseTrigger(TriggerKey.triggerKey("trigger3", "trigger-group1"));
//方式2:暂停所有该ID的任务实例,即所有触发器绑定的该任务的任务实例都会被暂停
scheduler.pauseJob(JobKey.jobKey("job4", "job-group1"));
```
<br/>
**2. 任务恢复执行**
>[info]任务暂停后的恢复执行
```java
//方式1:只恢复该触发器绑定的任务实例
scheduler.resumeTrigger(TriggerKey.triggerKey("trigger3", "trigger-group1"));
//方式2:恢复该ID的所有任务实例,即所有触发器绑定的该任务的任务实例都会恢复执行
scheduler.resumeJob(JobKey.jobKey("job4", "job-group1"));
```
<br/>
**3. 任务修改**
>[info]任务修改是指修改触发器,从而改变任务的执行规则;但对一个已经存在的 JobDetail 进行修改是不允许的。
```java
//获取旧触发器
TriggerKey triggerKey = TriggerKey.triggerKey("trigger3", "trigger-group1");
Trigger odlTrigger = scheduler.getTrigger(triggerKey);
//创建新的触发器
Trigger newTrigger = TriggerBuilder.newTrigger()
.withIdentity(triggerKey)
.startNow()
.withDescription(odlTrigger.getDescription())
.withSchedule(
SimpleScheduleBuilder.simpleSchedule()
.withIntervalInSeconds(2)
.repeatForever()
)
.build();
//用新的触发器覆盖旧的触发器,注意新旧触发器的ID不变
scheduler.rescheduleJob(triggerKey, newTrigger);
```
```
/// 打印的日志 ///
2023-03-31T18:40:20 ...UserJob : 触发器ID: trigger-group1.trigger3
2023-03-31T18:40:20 ...UserJob : 任务ID: job-group1.job4
...
2023-03-31T18:40:24 ...UserJob : 触发器ID: trigger-group1.trigger3
2023-03-31T18:40:24 ...UserJob : 任务ID: job-group1.job4
...
//之前是每隔 4s 执行一次,修改为每隔 2s 执行一次
2023-03-31T18:40:27 ...UserJob : 触发器ID: trigger-group1.trigger3
2023-03-31T18:40:27 ...UserJob : 任务ID: job-group1.job4
...
2023-03-31T18:40:29 ...UserJob : 触发器ID: trigger-group1.trigger3
2023-03-31T18:40:29 ...UserJob : 任务ID: job-group1.job4
```
<br/>
**4. 任务删除**
```java
//方式1:只删除该触发器绑定的 JobDetail 实例。
// 所以此时你重新创建了一个同 ID 的任务是不可以的,因为这个任务的定义还存在
TriggerKey triggerKey = TriggerKey.triggerKey("trigger3", "trigger-group1");
//暂停触发器
scheduler.pauseTrigger(triggerKey);
//移除触发器
scheduler.unscheduleJob(triggerKey);
//方式2:删除所有的 JobDetail 实例并也已删除了 JobDetail 的定义,
// 所以此时已不存在同 ID 的任务,你可以重新创建该任务了
scheduler.deleteJob(JobKey.jobKey("job4", "job-group1"));
```
<br/>
**5. 查询所有的任务实例**
>[info]可以获取所有正在运行、或已暂停的任务实例,当然删除的就获取不到了
```java
//获取所有的触发器组
List<String> triggerGroups = scheduler.getTriggerGroupNames();
for (String group : triggerGroups) {
GroupMatcher<TriggerKey> groupMatcher = GroupMatcher.groupEquals(group);
//获取该组所有的触发器
Set<TriggerKey> triggerKeys = scheduler.getTriggerKeys(groupMatcher);
for (TriggerKey triggerKey : triggerKeys) {
Trigger trigger = scheduler.getTrigger(triggerKey);
//触发器状态,NORMAL正在运行、PAUSED已经暂停
String state = scheduler.getTriggerState(triggerKey).name();
//获取该触发器绑定的任务
JobKey jobKey = trigger.getJobKey();
JobDetail jobDetail = scheduler.getJobDetail(jobKey);
log.info("触发器ID: {}, 触发器状态: {}", triggerKey.getGroup() + "." + triggerKey.getName(), state);
log.info("任务ID: {}\n", jobKey.getGroup() + "." + jobKey.getName());
}
}
```
```
/// 打印日志 ///
2023-03-31T19:31:18...er.UserJobController : 触发器ID: trigger-group1.trigger5, 触发器状态: NORMAL
2023-03-31T19:31:18...er.UserJobController : 任务ID: job-group1.job4
2023-03-31T19:31:18...er.UserJobController : 触发器ID: trigger-group1.trigger4, 触发器状态: NORMAL
2023-03-31T19:31:18...er.UserJobController : 任务ID: job-group1.job4
2023-03-31T19:31:18...er.UserJobController : 触发器ID: trigger-group1.trigger3, 触发器状态: PAUSED
2023-03-31T19:31:18...er.UserJobController : 任务ID: job-group1.job4
```
- Mybatis
- mybatis是什么
- mybatis优缺点
- 环境搭建
- 使用步骤
- 传参方式
- 无需传参
- 一个参数
- 多个参数
- 增/删/改
- 查询
- 单表查询
- 一对一查询
- 一对多查询
- 动态SQL
- 注解操作
- Spring
- Spring什么
- Spring优点
- Spring组成
- 第一个Spring程序
- 两大核心技术
- IoC控制反转
- IoC思想
- IoC容器使用步骤
- 属性注入
- IoC注入方式
- 模拟IoC实现
- AOP
- AOP概念
- AOP原理
- AOP关键术语
- AOP编程过程
- 切入点规则
- 5种增强方式
- Spring注解开发
- 注解开发的优势
- Bean注解开发
- AOP注解开发
- 完全注解开发
- 模拟Spring注解开发
- 自动装配
- 配置文件拆分
- SpringBean
- Bean常用属性
- Bean的作用域
- Bean的生命周期
- Spring整合MyBatis
- 整合步骤
- SqlSessionTemplate
- 业务层添加事务
- 事务的作用
- 配置文件事务
- 注解事务
- 事务参数
- SpringMVC
- SpringMVC是什么
- 环境搭建
- 请求流程
- 核心组件
- 前后端交互
- 简单交互演示
- 常用注解
- 后端数据传递至前端
- ServletAPI
- 访问静态资源
- 异常处理
- HandlerExceptionResolver
- 局部异常
- 全局异常
- 转发与重定向
- 转发演示
- 重定向演示
- 转发与重定向的区别
- 获取表单数据
- 表单标签
- REST风格的URL
- 异步处理
- 异步请求
- JSON数据处理
- 中文乱码处理
- 日期处理
- 上传文件
- 拦截器
- 视图解析器
- 视图类型
- 多视图解析器
- 自定义pdf视图
- JSR303数据验证
- JSR303是什么
- 常用约束
- 使用步骤
- SpringMVC整合Mybatis
- 整合步骤
- Mybatis分页插件
- SpringBoot
- SpringBoot是什么
- 环境搭建
- SpringBoot启动分析
- SpringBoot启动类
- 启动过程
- SpringBoot配置文件
- 配置文件类型
- 更改配置文件
- 读取配置文件
- 占位符
- 配置优先级
- 自定义IoC容器
- 定义方式
- 引入Spring配置文件
- @Configuration
- SpringBoot自动配置
- 自动配置原理
- 条件注解
- 自动配置报告
- 自定义自动配置
- 关闭自动配置
- 接管自动配置
- 多环境配置
- CommandLineRunner
- SpringBoot与Web开发
- 引入模板引擎
- Thymeleaf模板
- Freemarker模板
- 静态资源访问
- webjars
- 静态资源位置
- ico图标
- 指定首页
- 更换Web服务器
- 国际化
- 拦截器
- 错误处理机制
- 错误处理机制原理
- 定制错误页面
- 定制错误数据
- 上传文件
- 注册servlet三大组件
- 注册Servlet
- 注册过滤器
- 注册监听器
- 外部Tomcat与jsp模板
- 前后端交互
- 传递json字符串
- 传递js对象
- 传递表单
- 下载功能
- Swagger2文档
- SpringBoot整合JDBC
- 整合步骤
- 核心API
- JdbcTemplate
- 增删改
- 查询
- NamedParameterJdbcTemplate
- 增删改
- 查询
- SpringBoot整合Mybatis
- 整合步骤
- 切换为Druid数据源
- 添加事务
- Mybatis分页插件
- 场景启动器
- 场景启动器是什么
- 自定义场景启动器
- SpringBoot与日志
- 日志框架
- slf4j日志
- slf4j日志实现
- 统一切换为slf4j
- 日志配置
- 日志文件
- 切换日志框架
- 切换日志场景启动器
- SpringBoot与缓存
- JSR107缓存技术
- Spring缓存抽象
- 缓存注解
- SpEL表达式
- 使用缓存
- 自定义key生成器
- 缓存工作原理与流程
- SpringBoot整合Redis
- 整合步骤
- 初步使用
- 序列化机制
- 缓存管理器
- SpringBoot与任务
- 异步任务
- 实现异步任务
- 注意事项与原理
- 自定义线程池
- 定时任务
- cron表达式
- 创建定时任务
- @Scheduled参数
- 动态时间
- 邮件任务
- Quartz定时任务
- Quartz是什么
- 创建定时任务
- 触发器与任务
- 任务的CURD
- 两种触发器
- 并发问题
- 持久化
- 任务持久化
- Quartz集群
- misfire策略
- 打包插件
- appassembler-maven-plugin
- appassembler与assembly配合