Quartz使用H2数据库(嵌入模式)进行持久化

news2025/1/2 4:37:18

使用H2(嵌入模式)持久化Quartz任务

🔝前言:

Quartz在包内提供了多种数据库的sql文件,大家可以选择方便的使用。路径如下。
请添加图片描述

1.初始化h2(不使用Server模式)

public class InitH2 {
	
	private static String USER_NAME = "lee";
	
	private static String PASSWORD = "";
	/**
	 * 数据库的URL,初始化会在指定的目录下创建.db数据库文件
	 * (PS:该db文件不能被两个进程同时使用,请现关闭数据量工具的连接再运行程序)
	 * Server模式请使用jdbc:h2:tcp://<server>[:<port>]/[<path>]<databaseName>
	 */
	private static String JDBC_URL = "jdbc:h2:./qtest.db";
	
	/**
	 * 驱动类
	 */
	private static String DRIVER_NAME = "org.h2.Driver";
	
	
	public static void main(String[] args) throws ClassNotFoundException, SQLException {
		
		 Class.forName(DRIVER_NAME);
		 
		 Connection connection = DriverManager.getConnection(JDBC_URL, USER_NAME, PASSWORD);
		 
	}
}

使用数据库连接工具创建需要的表

请添加图片描述

2.修改Quartz的配置文件

Quartz包中有默认的properties配置文件,可以直接复制出来进行修改。

这是原包内的配置文件:

org.quartz.scheduler.instanceName: DefaultQuartzScheduler
org.quartz.scheduler.rmi.export: false
org.quartz.scheduler.rmi.proxy: false
org.quartz.scheduler.wrapJobExecutionInUserTransaction: false

org.quartz.threadPool.class: org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount: 10
org.quartz.threadPool.threadPriority: 5
org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread: true

org.quartz.jobStore.misfireThreshold: 60000

#只需要修改下面的内容
org.quartz.jobStore.class: org.quartz.simpl.RAMJobStore

修改后的配置文件:

org.quartz.scheduler.instanceName: DefaultQuartzScheduler
org.quartz.scheduler.rmi.export: false
org.quartz.scheduler.rmi.proxy: false
org.quartz.scheduler.wrapJobExecutionInUserTransaction: false

org.quartz.threadPool.class: org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount: 10
org.quartz.threadPool.threadPriority: 5
org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread: true

org.quartz.jobStore.misfireThreshold: 60000

#org.quartz.jobStore.class: org.quartz.simpl.RAMJobStore
org.quartz.jobStore.class:org.quartz.impl.jdbcjobstore.JobStoreTX 
#设置JDBC的代理,(根据数据库类型选择)
#有PointbaseDelegate
#PostgreSQLDelegate
#MSSQLDelegate
#OracleDelegate
#等类型,如果找不到专属的化,请使用标准的JDBC代理
org.quartz.jobStore.driverDelegateClass:org.quartz.impl.jdbcjobstore.StdJDBCDelegate 
#表名的前缀--不需要修改
org.quartz.jobStore.tablePrefix:qrtz_
#数据库名称  
org.quartz.jobStore.dataSource:PUBLIC

#数据源信息---注意dataSource后为数据库名称--需要更具实际情况修改
org.quartz.dataSource.PUBLIC.driver:org.h2.Driver
org.quartz.dataSource.PUBLIC.URL:jdbc:h2:./qtest.db
org.quartz.dataSource.PUBLIC.user:lee
org.quartz.dataSource.PUBLIC.password:

3.创建Trigger和Job并运行

测试执行任务后

public class InitH2 {
	private static String USER_NAME = "lee";
	private static String PASSWORD = "";
	/**
	 * 数据库的URL
	 */
	private static String JDBC_URL = "jdbc:h2:./qtest.db";
	/**
	 * 驱动类
	 */
	private static String DRIVER_NAME = "org.h2.Driver";
	
	public static void main(String[] args) throws ClassNotFoundException, SQLException, SchedulerException, InterruptedException {
		
		 //Class.forName(DRIVER_NAME);
		 
		 //Connection connection = DriverManager.getConnection(JDBC_URL, USER_NAME, PASSWORD);
		
		 StdSchedulerFactory factory = new StdSchedulerFactory();
		
		 StdScheduler scheduler = (StdScheduler)factory.getScheduler();
		 
		 SimpleTrigger trigger = TriggerBuilder.newTrigger().withIdentity("TOne").startNow().withDescription("测试持久化")
		 .withSchedule(SimpleScheduleBuilder.repeatSecondlyForever(5)).build();
		 
		 JobDetail jobDetail = JobBuilder.newJob(SimpleJob.class).withIdentity("JOne").build();
		 
		 scheduler.scheduleJob(jobDetail, trigger);
		 
		 scheduler.start();
		 
		 Thread.sleep(6000);
	}
	
	public static class SimpleJob implements Job{

		
		@Override
		public void execute(JobExecutionContext arg0) throws JobExecutionException {
			
			System.out.println("WDNMD");
			
		}
		
	}

}

请添加图片描述

运行结束后打开h2数据库,你的Scheduler绑定的Trigger和Job将会被保存到表中

4.从数据库中获取Trigger和Job直接使用

public class InitH2 {
	
	
	
	private static String USER_NAME = "lee";
	
	private static String PASSWORD = "";
	/**
	 * 数据库的URL
	 */
	private static String JDBC_URL = "jdbc:h2:./qtest.db";
	
	
	/**
	 * 驱动类
	 */
	private static String DRIVER_NAME = "org.h2.Driver";
	
	
	public static void main(String[] args) throws ClassNotFoundException, SQLException, SchedulerException, InterruptedException {
		
		
		StdSchedulerFactory factory = new StdSchedulerFactory();
		
		StdScheduler scheduler =  (StdScheduler)factory.getScheduler();
		
		Trigger trigger = scheduler.getTrigger(new TriggerKey("TOne"));
		
		JobDetail jobDetail = scheduler.getJobDetail(new JobKey("JOne"));
		
        //注意拿Trigger重新解绑一下Job,不然下面Scheduler会重复绑定报错
		scheduler.unscheduleJob(new TriggerKey("TOne"));
		
		scheduler.scheduleJob(jobDetail, trigger);
		
		scheduler.start();
		
		
		
		Thread.sleep(6000);
	}
	
	public static class SimpleJob implements Job{

		
		@Override
		public void execute(JobExecutionContext arg0) throws JobExecutionException {
			
			System.out.println("WDNMD");
			
		}
		
	}

}

请添加图片描述
(PS:如果不使用Cluster的话,Quartz不会持久化Scheduler(除非你在properties里配置了scheduler实例),所以不要纠结于QRTZ_SCHEDULER_STATE表为什么没有数据)

目录结构:
请添加图片描述

5.转移配置到SpringBoot中

待续

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/677321.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Unity简单操作:InputSystem获取WASD键盘输入 移动人物

目录 安装InputSystem 在编辑的脚本中使用 InputSystem生成的脚本 Unity版本&#xff1a;2019.2.3f1 安装InputSystem 菜单栏/Window/Package Manager/Input System 工程面板内 右键-->创建Input Actions 选中New Controls改名为PlayerControls 然后属性 面板按下Edit as…

软件项目管理 第七章 软件项目的质量管理与配置管理 课后习题参考答案——主编:李冰、张桥珍、刘玉娥

第七章 软件项目的质量管理与配置管理 课后习题参考答案 1.选择题 (1)项目质量管理的最终责任由谁来承担?&#xff08;D&#xff09; A.项目开发人员 B.采购经理 C.质量经理 D.项目经理 (2)“质量成本”是一个项目管理概念,它说明了下列哪项成本?…

HDFS 写流程源码分析

HDFS 写流程源码分析 一、客户端&#xff08;一&#xff09;文件创建及Pipeline构建阶段&#xff08;二&#xff09;数据写入&#xff08;三&#xff09;输出流关闭 二、NameNode端&#xff08;一&#xff09;create 环境为hadoop 3.1.3 一、客户端 以下代码创建并写入文件。 …

如何优雅地安装 Android Studio

&#x1f4ad; 写在前面&#xff1a;我们假设读者已经搞定 JDK 了&#xff0c;如果没搞定请先搜索 JDK 的安装教程。访问 Oracle JDK 下载页面&#xff1a;访问 Java Downloads | Oracle &#xff0c;点击 "JDK Download" 按钮。选择适合您操作系统的 JDK 版本&#…

设计模式之模板方法模式笔记

设计模式之模板方法模式笔记 说明Template Method(模板方法)目录模板方法模式示例类图抽象类包菜类菜心类测试类 说明 记录下学习设计模式-模板方法模式的写法。JDK使用版本为1.8版本。 Template Method(模板方法) 意图:定义一个操作中的算法骨架&#xff0c;而将一些步骤延…

yolo格式visdrone转换

目录 yolo格式转换1. Visdrone2019格式转换 yolo格式转换 1. Visdrone2019格式转换 数据集下载地址https://aistudio.baidu.com/aistudio/datasetdetail/115729 如果是visdrone数据集&#xff0c;直接使用txt2xml.py去转换&#xff0c;修改annotation和img的路径&#xff0c…

<Linux开发>驱动开发 -之- Linux LCD 驱动

&#xff1c;Linux开发&#xff1e;驱动开发 -之- Linux LCD 驱动 交叉编译环境搭建&#xff1a; &#xff1c;Linux开发&#xff1e; linux开发工具-之-交叉编译环境搭建 uboot移植可参考以下&#xff1a; &#xff1c;Linux开发&#xff1e; -之-系统移植 uboot移植过程详细…

网络基础一

网络发展 独立模式&#xff1a;计算机之间相互独立。 网络互联&#xff1a;多台计算机连接在一起&#xff0c;完成数据共享。 局域网LAN&#xff1a;计算机数量更多了&#xff0c;通过交换机和路由器连接在一起&#xff1b; 广域网WAN&#xff1a;将远隔千里的计算机都连在…

[BPU部署教程] 万字长文!通透解读模型部署端到端大流程——以终为始,以行为知

去年6月份拿到开发板到现在&#xff0c;转眼已经过去大半年了&#xff0c;这个博客11月初就在写&#xff0c;断断续续写到现在。C部署需要考虑的问题很多&#xff0c;如果只给个简单部署教程的话&#xff0c;就算整理出来&#xff0c;感觉帮助也不大&#xff0c;各位开发时候我…

YOLOv5改进系列(11)——添加损失函数之EIoU、AlphaIoU、SIoU、WIoU

【YOLOv5改进系列】前期回顾: YOLOv5改进系列(0)——重要性能指标与训练结果评价及分析 YOLOv5改进系列(1)——添加SE注意力机制

模版方法模式在 JDK 及 spring 源码中的应用

模版方法模式 模板方法模式是一种行为设计模式&#xff0c; 它在超类中定义了一个算法的框架&#xff0c; 允许子类在不修改结构的情况下重写算法的特定步骤。 更多有关于模版方法模式的介绍详见&#xff1a;https://refactoringguru.cn/design-patterns/template-method 模版…

津津乐道设计模式 - 委派模式详解(以家庭弟位让你彻底明白)

&#x1f337; 古之立大事者&#xff0c;不惟有超世之才&#xff0c;亦必有坚忍不拔之志 &#x1f390; 个人CSND主页——Micro麦可乐的博客 &#x1f425;《Docker实操教程》专栏以最新的Centos版本为基础进行Docker实操教程&#xff0c;入门到实战 &#x1f33a;《RabbitMQ》…

STM32 Proteus仿真DHT11温度湿度光敏光强DS1302闹钟-0044

STM32 Proteus仿真DHT11温度湿度光敏光强DS1302闹钟-0044 Proteus仿真小实验&#xff1a; STM32 Proteus仿真DHT11温度湿度光敏光强DS1302闹钟-0044 功能&#xff1a; 硬件组成&#xff1a; STM32F103C6T6单片机 DHT11温度湿度光敏电阻采集光强 多个按键模拟红外遥控1个LED…

node.js--vue仓库进销存管理信息系统whkb8

随着社会的发展&#xff0c;系统的管理形势越来越严峻。越来越多的用户利用互联网获得信息&#xff0c;但各种信息鱼龙混杂&#xff0c;信息真假难以辨别。为了方便用户更好的获得仓库管理信息&#xff0c;因此&#xff0c;设计一种安全高效的仓库管理信息系统极为重要。 为设计…

【从零开始学习JAVA | 第十五篇】 多态

前言&#xff1a; 本篇我们来解释一下什么是多态关系&#xff0c;多态关系属于面向对象三大特征的最后一个&#xff0c;可以说面向对象的重点就在多态&#xff0c;因此我们要学好面向对象编程思想&#xff0c;就要学好多态。 多态&#xff1a; Java中的多态是指同一类对象在不同…

nssctf之SSRF刷题记录

[NISACTF 2022]easyssrf 题目讲的主要是ssrf以及php伪协议的能力&#xff0c;题目详情如下 一般来说&#xff0c;当一个网站出现curl类的功能时就可能会出现ssrf之类的漏洞&#xff0c;常见的ssrf协议如下 file:/// dict:// sftp:// ldap:// tftp:// gopher://file:// 这种…

基于python的matplotlib、numpy库实现的图形绘制(数据可视化)

一、sin&#xff0c;cos函数 1.题目要求 编写程序&#xff0c;绘制正弦曲线和余弦曲线。 提示&#xff1a;利用numpy的linspace()、sin()或cos()函数生成样本数据、正弦或余弦值。 2.函数讲解及代码 import matplotlib.pyplot as plt import numpy as np#linspace函数是用…

【MySQL数据库 | 第二十篇】explain执行计划

目录 前言&#xff1a; explain&#xff1a; 语法&#xff1a; 总结&#xff1a; 前言&#xff1a; 上一篇我们介绍了从时间角度分析MySQL语句执行效率的三大工具&#xff1a;SQL执行频率&#xff0c;慢日志查询&#xff0c;profile。但是这三个方法也只是在时间角度粗略的…

kubernetes入门案例

kubernetes入门案例 本文我们通过一个 Java Web 应用例子来介绍 kubernetes 的使用&#xff0c;可以让新手快速上手和实践。 此 Java Web 应用的结构比较简单&#xff0c;是一个运行在 Tomcat 里的 Web App&#xff0c;JSP 页面通过 JDBC 直接访问 MySQL 数据库并展示数据。…

青梅产业成立“国家队”,溜溜梅迎来树立品牌良机?

扩大内需在今年政府工作报告中被频频提及。国务院发展研究中心原副主任王一鸣认为&#xff0c;激活潜在消费需求&#xff0c;将释放中国超大规模市场的经济增长潜力。 如今&#xff0c;休闲零食市场也正在经历这样一场激活潜在需求的变革。无论是洽洽食品、三只松鼠、良品铺子…