quartz

quartz 持久化数据库表格字段解释

建表,SQL语句在quartz-1.6.6\docs\dbTables文件夹中可以找到,介绍下主要的几张表:
       表qrtz_job_details: 保存job详细信息,该表需要用户根据实际情况初始化
       job_name:集群中job的名字,该名字用户自己可以随意定制,无强行要求
       job_group:集群中job的所属组的名字,该名字用户自己随意定制,无强行要求
       job_class_name:集群中个note job实现类的完全包名,quartz就是根据这个路径到classpath找到该job类
       is_durable:是否持久化,把该属性设置为1,quartz会把job持久化到数据库中
       job_data:一个blob字段,存放持久化job对象

       表qrtz_triggers: 保存trigger信息
       trigger_name: trigger的名字,该名字用户自己可以随意定制,无强行要求
       trigger_group:trigger所属组的名字,该名字用户自己随意定制,无强行要求
       job_name: qrtz_job_details表job_name的外键
       job_group: qrtz_job_details表job_group的外键
       trigger_state:当前trigger状态,设置为ACQUIRED,如果设置为WAITING,则job不会触发
       trigger_cron:触发器类型,使用cron表达式

       表qrtz_cron_triggers:存储cron表达式表
       trigger_name: qrtz_triggers表trigger_name的外键
       trigger_group: qrtz_triggers表trigger_group的外键
       cron_expression:cron表达式
      
       表qrtz_scheduler_state:存储集群中note实例信息,quartz会定时读取该表的信息判断集群中每个实例的当前状态
       instance_name:之前配置文件中org.quartz.scheduler.instanceId配置的名字,就会写入该字段,如果设置为AUTO,quartz会根据物理机名和当前时间产生一个名字
       last_checkin_time:上次检查时间
       checkin_interval:检查间隔时间

步骤4 :
      配置quartz.properties文件

# 调度标识名 集群中每一个实例都必须使用相同的名称 org.quartz.scheduler.instanceName = scheduler#ID设置为自动获取 每一个必须不同 org.quartz.scheduler.instanceId = AUTO#数据保存方式为持久化 org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX#数据库平台 org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.oracle.weblogic.WebLogicOracleDelegate #数据库别名 随便取org.quartz.jobStore.dataSource = myXADS#表的前缀 org.quartz.jobStore.tablePrefix = QRTZ_#设置为TRUE不会出现序列化非字符串类到 BLOB 时产生的类版本问题 org.quartz.jobStore.useProperties = true#加入集群 org.quartz.jobStore.isClustered = true#调度实例失效的检查时间间隔 org.quartz.jobStore.clusterCheckinInterval = 20000 #容许的最大作业延长时间 org.quartz.jobStore.misfireThreshold = 60000#ThreadPool 实现的类名 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.dataSource.myXADS.jndiURL = CT#jbdi类名 org.quartz.dataSource.myXADS.java.naming.factory.initial = weblogic.jndi.WLInitialContextFactory #URLorg.quartz.dataSource.myXADS.java.naming.provider.url = t3://localhost:7001

03-08
### Quartz 调度框架使用指南 #### 一、初步认识Quartz 为了快速掌握Quartz议先从官方文档的Introduction部分入手,这里会介绍Quartz的核心概念及其组成要素[^1]。 #### 二、实践操作 接着应该浏览Tutorials & Examples章节,在实际案例指导下完成基本设置与编程工作。这有助于加深对理论的理解并积累实践经验。 对于具体的实现细节,下面给出一段简单的代码示例来展示如何创一个基于Quartz的任务调度程序: ```java import org.quartz.*; import static org.quartz.JobBuilder.newJob; import static org.quartz.SimpleScheduleBuilder.simpleSchedule; import static org.quartz.TriggerBuilder.newTrigger; public class SimpleExample { public void run() throws SchedulerException { // 创调度器实例 StdSchedulerFactory factory = new StdSchedulerFactory(); Scheduler scheduler = factory.getScheduler(); // 定义job详情, 并关联到MyJob类 JobDetail job = newJob(MyJob.class).withIdentity("myJob", "group1").build(); // 构触发器trigger使其每十秒执行一次 Trigger trigger = newTrigger().withIdentity("myTrigger", "group1") .startNow() .withSchedule(simpleSchedule().withIntervalInSeconds(10).repeatForever()) .build(); // 把job和trigger注册至scheduler内 scheduler.scheduleJob(job, trigger); // 启动调度器 scheduler.start(); try { Thread.sleep(60 * 1000); } catch (Exception e) {} // 关闭调度器 scheduler.shutdown(true); } } ``` 这段代码展示了怎样定义一个新的任务(`MyJob`)并通过`SimpleTrigger`设定其每隔十秒钟重复执行一次的方式加入到了调度队列当中[^4]。 #### 三、深入探究 当遇到特定难题时,则可参照Configuration Reference同API Documentation获取更详尽的帮助材料;同时也可以探索更多高级特性比如持久化存储机制(JobStore),它负责保存运行期间产生的各类元数据如Trigger、Scheduler、JobDetail等信息[^5]。 另外值得注意的是,通过`JobExecutionContext`对象可以在执行过程中获得当前上下文环境以及有关该次调用的具体参数[^3]。 #### 四、持续学习 最后推荐关注相关资源和支持渠道以便于长期跟进项目发展动态和技术交流活动。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值