Quartz(2-Trigger)
相关文章链接
- 定时任务工具类(Cron Util)
- SpringBoot Task
- Quartz(1-Job)
- Quartz(2-Trigger)
Trigger
方法
- 优先级(priority)
如果你的 trigger 很多(或者 Quartz 线程池的工作线程太少),Quartz 可能没有足够的资源同时触发所有的 trigger;这种情况下,你可能希望控制哪些 trigger 优先使用 Quartz 的工作线程,要达到该目的,可以在 trigger 上设置 priority 属性。
比如,你有 N 个 trigger 需要同时触发,但只有 Z 个工作线程,优先级最高的 Z 个 trigger 会被首先触发
- 错过触发(misfire instructions)
如果 scheduler 关闭了,或者 Quartz 线程池中没有可用的线程来执行 job,此时持久性的 trigger 就会错过(miss)其触发时间,即错过触发(misfire)。当下次调度器启动或者有可以线程时,会检查处于 misfire 状态的 Trigger。而 misfire 的状态值决定了调度器如何处理这个 Trigger。
不同类型的 trigger,有不同的 misfire 机制。它们默认都使用“智能机制(smart policy)”,即根据 trigger 的类型和配置动态调整行为
分类
SimpleTrigger
为需要在特定的日期/时间启动,且以一个可能的间隔时间重复执行 n 次的 job 所设计的
- startNow():Scheduler 开始执行时,触发器也即执行
- startAt():在指定的时间开始执行
- endAt():结束时间
执行间隔:
- withInterval(TimeSpan timeSpan):通用的间隔执行方法
- withIntervalInHours(int hours):以小时为间隔单位进行执行
- withIntervalInMinutes(int minutes):以分钟为间隔单位进行执行
- withIntervalInSeconds(int seconds):以秒为间隔单位进行执行
执行时间:
- withRepeatCount(int repeatCount):执行多少次以后结束
- repeatForever():永远执行
- repeatMinutelyForever():一分钟执行一次(永远执行)
- repeatMinutelyForever(int minutes):每隔几分钟执行一次(永远执行)
- repeatMinutelyForTotalCount(int count, int minutes):每隔几分钟执行一次(执行次数为 count)类似的还有秒、小时。
public class Trigger1 {public static void main(String[] args) throws SchedulerException {//创建一个 JobDetail 的实例,将该实例与 HelloJob 绑定JobDetail jobDetail = JobBuilder.newJob(HelloJob.class).withIdentity("testJob").build();//开始时间 3 秒钟之后 (具体时间按实际业务编写)Date sData = new Date();sData.setTime(sData.getTime() + 3000);//结束时间 20 秒钟之后 (具体时间按实际业务编写)Date eData = new Date();eData.setTime(eData.getTime() + 20000);//创建一个 Trigger 实例,定义该 job3 秒之后执行,在 6 秒之后结束SimpleTrigger zhlTrigger = TriggerBuilder.newTrigger().withIdentity("test").startAt(sData) //设定开始时间.endAt(eData) //设定结束时间.withSchedule(SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(2) //每两秒打印一次.withRepeatCount(2)) // 重复 2 次.build();//创建 Scheduler 实例StdSchedulerFactory stdSchedulerFactory = new StdSchedulerFactory();Scheduler scheduler = stdSchedulerFactory.getScheduler();scheduler.start();scheduler.scheduleJob(jobDetail, zhlTrigger);}
}
public class HelloJob implements Job{public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {//打印当前的执行时间 例如 2017-11-22 00:00:00Date date = new Date();SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");System.out.println("现在的时间是:"+ sf.format(date));//具体的业务逻辑System.out.println("具体执行的业务...");JobKey key = jobExecutionContext.getJobDetail().getKey();Trigger trigger = jobExecutionContext.getTrigger();System.out.println("开始的时间:"+sf.format(trigger.getStartTime()));System.out.println("结束的事件:"+sf.format(trigger.getEndTime()));}
}
CronTrigger
指定对应的 cron 表达式执行任务
public class Trigger2 {public static void main(String[] args) throws SchedulerException {//创建一个 JobDetail 的实例,将该实例与 HelloJob 绑定JobDetail jobDetail = JobBuilder.newJob(HelloJob.class).withIdentity("test").build();//开始时间 3 秒钟之后 (具体时间按实际业务编写)Date sData = new Date();sData.setTime(sData.getTime() + 3000);//结束时间 20 秒钟之后 (具体时间按实际业务编写)Date eData = new Date();eData.setTime(eData.getTime() + 20000);//创建一个 Trigger 实例,定义该 job3 秒之后执行,在 6 秒之后结束CronTrigger trigger = TriggerBuilder.newTrigger().withIdentity("testTrigger").startAt(sData) //设定开始时间.endAt(eData) //设定结束时间.withSchedule(CronScheduleBuilder.cronSchedule("0/3 * * * * ?")).build();//创建 Scheduler 实例StdSchedulerFactory stdSchedulerFactory = new StdSchedulerFactory();Scheduler scheduler = stdSchedulerFactory.getScheduler();scheduler.start();scheduler.scheduleJob(jobDetail, trigger);}
}
CalendarIntervalTrigger
用来触发基于定时重复的 JobDetail,Trigger 将会每隔 N 个 Calendar 在 Trigger 中定义的时间单元触发一次,这个 Trigger 不适合使用 SimpleTrigger 完成(例如由于每一个月的时间不是固定的描述),也不适用于 CronTrigger(例如每 5 个月)
相较于 SimpleTrigger 有两个优势:
- 更方便,比如:每隔 1 小时执行,你不用自己去计算 1 小时等于多少毫秒。
- 支持不是固定长度的间隔,比如:间隔为月和年。但劣势是精度只能到秒。
参数:
- interval:执行间隔
- intervalUnit:执行间隔的单位(秒、分钟、小时、天、月、年、星期)
public class Trigger4 {public static void main(String[] args) throws SchedulerException {//创建一个 JobDetail 的实例,将该实例与 HelloJob 绑定JobDetail jobDetail = JobBuilder.newJob(HelloJob.class).withIdentity("test").build();//开始时间 3 秒钟之后 (具体时间按实际业务编写)Date sData = new Date();sData.setTime(sData.getTime() + 3000);//结束时间 20 秒钟之后 (具体时间按实际业务编写)Date eData = new Date();eData.setTime(eData.getTime() + 20000);//创建一个 Trigger 实例,定义该 job3 秒之后执行,在 20 秒之后结束CalendarIntervalTrigger intervalTrigger = TriggerBuilder.newTrigger().withIdentity("testTrigger").startAt(sData) //设定开始时间.endAt(eData) //设定结束时间.withSchedule(CalendarIntervalScheduleBuilder.calendarIntervalSchedule().withIntervalInSeconds(5)) // 每隔 5 秒执行一次.build();//创建 Scheduler 实例StdSchedulerFactory stdSchedulerFactory = new StdSchedulerFactory();Scheduler scheduler = stdSchedulerFactory.getScheduler();scheduler.start();scheduler.scheduleJob(jobDetail, intervalTrigger);}
}
DailyTimeIntervalTrigger
指定每天的某个时间段内,以一定的时间间隔执行任务,并且可以支持星期的设置
适合的任务类似于:指定每天 9:00 至 18:00,每隔 10 秒执行一次,并且只要周一至周五执行
参数:
- onEveryDay:每天
- onMondayThroughFriday:周一至周五,即工作日
- onSaturdayAndSunday:周六至周天,即休息日 e
- onDaysOfTheWeek:用数组的形式单独来指定一周中的哪几天
- startingDailyAt:表示开始于几点 (区别于前面的 StartAt)
- endingDailyAt:表示结束于几点 (区别于前面的 EndAt)
public class Trigger3 {public static void main(String[] args) throws SchedulerException {//创建一个 JobDetail 的实例,将该实例与 HelloJob 绑定JobDetail jobDetail = JobBuilder.newJob(HelloJob.class).withIdentity("test").build();//开始时间 3 秒钟之后 (具体时间按实际业务编写)Date sData = new Date();sData.setTime(sData.getTime() + 3000);//结束时间 20 秒钟之后 (具体时间按实际业务编写)Date eData = new Date();eData.setTime(eData.getTime() + 20000);//创建一个 Trigger 实例,定义该 job3 秒之后执行,在 20 秒之后结束DailyTimeIntervalTrigger trigger = TriggerBuilder.newTrigger().withIdentity("testTrigger").startAt(sData) //设定开始时间.endAt(eData) //设定结束时间.withSchedule(DailyTimeIntervalScheduleBuilder.dailyTimeIntervalSchedule().withIntervalInSeconds(3).onEveryDay()) //每天每隔 3 秒执行一次.build();//创建 Scheduler 实例StdSchedulerFactory stdSchedulerFactory = new StdSchedulerFactory();Scheduler scheduler = stdSchedulerFactory.getScheduler();scheduler.start();scheduler.scheduleJob(jobDetail, trigger);}
}
MutableTrigger
Trigger 只是定义了相关属性的 Get 方法,并没有 Set 方法,而 MutableTrigger 接口则定义了相关属性的 set 方法,如:setKey 方法。
OperableTrigger
OperableTrigger 接口从字面上来说时可操作的 Trigger,也就是 Trigger 被 QuartzSchedulerThread 获取到之后,在不同情况下需要进行操作的接口。
- computeFirstFireTime:计算第一次触发时间。
- triggered:trigger 被触发时调用的方法。
- updateAfterMisfire:对应触发器失火后调用的方法。
- executionComplete:触发器本次触发完成时被调用的方法。
相关文章:

Quartz(2-Trigger)
相关文章链接 定时任务工具类(Cron Util)SpringBoot TaskQuartz(1-Job)Quartz(2-Trigger) Trigger 方法 优先级(priority) 如果你的 trigger 很多(或者 Quartz 线程…...

【微信小程序开发 - 3】:项目组成介绍
文章目录 项目组成介绍项目的基本组成结构小程序页面的组成部分JSON配置文件的作用app.json文件project.config.json文件sitemap.json文件页面的 .json 配置文件新建小程序页面修改项目首页 XWML模板XWML 和 HTML 的区别 WXSS样式WXSS 和 CSS 的区别 .js文件 项目组成介绍 项目…...

Leetcode 三角形最小路径和
算法思想与代码详解 这段代码采用的是**动态规划(Dynamic Programming)**的思想,用来解决“120. 三角形最小路径和”问题。动态规划通过将问题分解成更小的子问题,并通过保存子问题的解来避免重复计算,从而提高效率。…...

DataOps驱动数据集成创新:Apache DolphinScheduler SeaTunnel on Amazon Web Services
引言 在数字化转型的浪潮中,数据已成为企业最宝贵的资产之一。DataOps作为一种文化、流程和实践的集合,旨在提高数据管道的质量和效率,从而加速数据从源头到消费的过程。白鲸开源科技,作为DataOps领域的领先开源原生公司…...

Android Studio的笔记--BusyBox相关
BusyBox 相关 BusyBoxandroid上安装busybox和使用示例一、下载二、移动三、安装和设置环境变量四、使用 busybox源码下载和查看 BusyBox BUSYBOX BUSYBOX链接https://busybox.net/ 点击链接后如图 点击左边菜单栏的Get BusyBix中的Download Source 跳转到busybox 的下载源码…...

MySQL 存储过程与函数:增强数据库功能
一、MySQL 存储过程与函数概述 (一)存储过程的定义与特点 存储过程是一组预编译的 SQL 语句集合,它们被存储在数据库中,可根据需要被重复调用。例如,在一个电商系统中,经常需要查询某个时间段内的订单数据…...

网络安全(3)_安全套接字层SSL
4. 安全套接字层 4.1 安全套接字层(SSL)和传输层安全(TLS) (1)SSL/TLS提供的安全服务 ①SSL服务器鉴别,允许用户证实服务器的身份。支持SSL的客户端通过验证来自服务器的证书,来鉴别…...

Git 快速入门
Git 是什么? Git 是一个分布式版本控制系统四大区域: 工作区:项目文件的当前状态,即本地目录。暂存区:保存将要提交的文件快照,是一个中间层,使用git add将文件添加到暂存区。本地仓库…...

AI学习记录 - 依据 minimind 项目入门
想学习AI,还是需要从头到尾跑一边流程,最近看到这个项目 minimind, 我也记录下学习到的东西,需要结合项目的readme看。 1、github链接 https://github.com/jingyaogong/minimind?tabreadme-ov-file 2、硬件环境:英伟达4070ti …...

数据结构----链表头插中插尾插
一、链表的基本概念 链表是一种线性数据结构,它由一系列节点组成。每个节点包含两个主要部分: 数据域:用于存储数据元素,可以是任何类型的数据,如整数、字符、结构体等。指针域:用于存储下一个节点&#…...

设计模式-读书笔记
确认好: 模式名称 问题:在何时使用模式,包含设计中存在的问题以及问题存在的原因 解决方案:设计模式的组成部分,以及这些组成部分之间的相互关系,各自的职责和协作方式,用uml类图和核心代码描…...

c语言----选择结构
基本概念 选择结构是C语言中用于根据条件判断来执行不同代码块的结构。它允许程序在不同的条件下执行不同的操作,使程序具有决策能力。 if语句 单分支if语句 语法格式: if (条件表达式) { 执行语句块; } 功能: 当条件表达式的值为真&#…...

KS曲线python实现
目录 实战 实战 # 导入第三方模块 import pandas as pd import numpy as np import matplotlib.pyplot as plt# 自定义绘制ks曲线的函数 def plot_ks(y_test, y_score, positive_flag):# 对y_test重新设置索引y_test.index np.arange(len(y_test))# 构建目标数据集target_dat…...

解决matplotlib中文乱码问题
进入python,查看缓存 import matplotlib as mpl print(mpl.get_cachedir())如果结果为/Users/xxx/.matplotlib 那么就rm -rf /Users/xxx/.matplotlib 然后 mkdir ~/.fonts cd ~/.fonts wget http://129.204.205.246/downloads/SimHei.ttfsudo apt-get install fo…...

实操给桌面机器人加上超拟人音色
前面我们讲了怎么用CSK6大模型开发板做一个桌面机器人充当AI语音助理,近期上线超拟人方案,不仅大模型语音最快可以1秒内回复,还可以让我们的桌面机器人使用超拟人音色、具备声纹识别等能力,本文以csk6大模型开发板为例实操怎么把超…...

git stash 的文件如何找回
在Git中,如果你使用了git stash命令来保存你的工作进度,但之后想要找回这些被stash的文件,你可以按照以下步骤进行操作: 1. 查看stash列表 首先,使用git stash list命令来查看当前保存的所有stash记录。这个命令会列出…...

皮肤伤口分割数据集labelme格式248张5类别
数据集格式:labelme格式(不包含mask文件,仅仅包含jpg图片和对应的json文件) 图片数量(jpg文件个数):284 标注数量(json文件个数):284 标注类别数:5 标注类别名称:["bruises","burns","cu…...

uni-app开发AI康复锻炼小程序,帮助肢体受伤患者康复!
**提要:**近段时间我们收到多个康复机构用户,咨询AI运动识别插件是否可以应用于肢力运动受限患者的康复锻炼中来,插件是可以应用到AI康复锻炼中的,今天小编就为您介绍一下AI运动识别插件在康腹锻炼中的应用场景。 一、康复机构的应…...

双内核架构 Xenomai 4 安装教程
Xenomai 4是一种双内核架构, 继承了Xenomai系列的特点,通过在Linux内核中嵌入一个辅助核心(companion core),来提供实时能力。这个辅助核心专门处理那些需要极低且有界响应时间的任务。 本文将在官网教程(https://evlproject.org/…...

【redis的使用、账号流程、游戏服Handler的反射调用】1.自增id 2.全局用户名这样子名字唯一 3.
一、web服 1)账号注册 // 用于唯一命名服务 com.xinyue.game.center.business.account.logic.AccountRegisterService#accountRegister public void accountRegister(AccountEntity account) {accountManager.checkUsername(account.getUsername());accountManager.checkPass…...

neo4j 图表数据导入到 TuGraph
neo4j 图表数据导入到 TuGraph 代码文件说明后文 前言:近期在引入阿里的 TuGraph 图数据库,需要将 原 neo4j 数据导入到新的 tugraph 数据库中。预期走csv文件导入导出,但因为格式和数据库设计问题,操作起来比较麻烦(可能是个人没…...

启动报错java.lang.NoClassDefFoundError: ch/qos/logback/core/status/WarnStatus
报错信息图片 日志: Exception in thread "Quartz Scheduler [scheduler]" java.lang.NoClassDefFoundError: ch/qos/logback/core/status/WarnStatus先说我自己遇到的问题,我们项目在web设置了自定义的log输出路径,多了一个 / 去…...

【ubuntu18.04】ubuntu18.04挂在硬盘出现 Wrong diagnostic page; asked for 1 got 8解决方案
错误日志 [ 8754.700227] usb 2-3: new full-speed USB device number 3 using xhci_hcd [ 8754.867389] usb 2-3: New USB device found, idVendor0e0f, idProduct0002, bcdDevice 1.00 [ 8754.867421] usb 2-3: New USB device strings: Mfr1, Product2, SerialNumber0 [ 87…...

kubeadm安装K8s高可用集群之集群初始化及master/node节点加入calico网络插件安装
系列文章目录 1.kubeadm安装K8s高可用集群之基础环境配置 2.kubeadm安装K8s集群之高可用组件keepalivednginx及kubeadm部署 3.kubeadm安装K8s高可用集群之集群初始化及master/node节点加入集群calico网络插件安装 kubeadm安装K8s高可用集群之集群初始化及master/node节点加入ca…...

游戏何如防抓包
游戏抓包是指在游戏中,通过抓包工具捕获和分析游戏客户端与服务器之间传输的封包数据的过程。抓包工具可实现拦截、篡改、重发、丢弃游戏的上下行数据包,市面上常见的抓包工具有WPE、Fiddler和Charles Proxy等。 抓包工具有两种实现方式,一类…...

【LeetCode】每日一题 2024_12_19 找到稳定山的下标(模拟)
前言 每天和你一起刷 LeetCode 每日一题~ 最近力扣的每日一题出的比较烂,难度过山车,导致近期的更新都三天打鱼,两天断更了 . . . LeetCode 启动! 题目:找到稳定山的下标 代码与解题思路 先读题:最重要…...

运维 mysql、redis 、RocketMQ性能排查
MySQL查看数据库连接数 1. SHOW STATUS命令-查询当前的连接数 MySQL 提供了一个 SHOW STATUS 命令,可以用来查看服务器的状态信息,包括当前的连接数。 SHOW STATUS LIKE Threads_connected;这个命令会返回当前连接到服务器的线程数,即当前…...

[SAP ABAP] 将内表数据转换为HTML格式
从sflight数据库表中检索航班信息,并将这些信息转换成HTML格式,然后下载或显示在前端 开发步骤 ① 自定义一个数据类型 ty_sflight 来存储航班信息 ② 声明内表和工作区变量,用于存储表头、字段、HTML内容和航班详细信息以及创建字段目录lt…...

LLM大语言模型私有化部署-使用Dify与Qwen2.5打造专属知识库
背景 Dify 是一款开源的大语言模型(LLM) 应用开发平台。其直观的界面结合了 AI 工作流、 RAG 管道、 Agent 、模型管理、可观测性功能等,让您可以快速从原型到生产。相比 LangChain 这类有着锤子、钉子的工具箱开发库, Dify 提供了更接近生产需要的完整…...

使用C语言连接MySQL
在C语言中连接MySQL数据库,通常需要使用MySQL提供的C API。以下是使用C语言连接MySQL数据库的基本步骤和示例代码: 步骤 1: 安装MySQL C API 首先,确保你的系统上安装了MySQL数据库,并且安装了MySQL C API库。在大多数Linux发行版…...