quartz 表结构、配置文件、实现说明

一、表说明(建表,SQL语句在quartz-1.6.6\docs\dbTables文件夹中可以找到)

表名说明
qrtz_calendars以 Blob 类型存储 Quartz 的 Calendar 信息
qrtz_cron_triggers存储 Cron Trigger,包括 Cron 表达式和时区信息
qrtz_fired_triggers存储与已触发的 Trigger 相关的状态信息,以及相联 Job 的执行信息
qrtz_paused_trigger_grps存储已暂停的 Trigger 组的信息
qrtz_scheduler_state存储少量的有关调度器 (Scheduler) 的状态,和别的 调度器 (Scheduler)实例(假如是用于一个集群中)
qrtz_locks存储程序的非观锁的信息(假如使用了悲观锁)
qrtz_job_details存储每一个已配置的 Job 的详细信息(jobDetail)
qrtz_job_listeners存储有关已配置的 Job 监听器 的信息
qrtz_simple_triggers存储简单的 Trigger,包括重复次数,间隔,以及已触的次数
qrtz_blog_triggers以 Blob 类型存储的Trigger
(用于 Quartz 用户用 JDBC 创建他们自己定制的 Trigger 类型,JobStore 并不知道如何存储实例的时候)
qrtz_trigger_listeners存储已配置的触发器监听器 ( Trigger Listener ) 的信息
qrtz_triggers存储已配置的 触发器 (Trigger) 的信息

二、表结构说明

      表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状态,( WAITING:等待 PAUSED:暂停ACQUIRED:正常执行 BLOCKED:阻塞 ERROR:错误。   当   (当设置为WAITING时JOB不触发)
       trigger_type:触发器类型,CRON、SIMPLE

       表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:检查间隔时间 

三、quartz配置文件

Quartz提供两种基本作业存储类型

第一种类型叫做RAMJobStore:
     最佳的性能,因为内存中数据访问最快
     不足之处是缺乏数据的持久性,当程序路途停止或系统崩溃时,所有运行的信息都会丢失
第二种类型叫做JDBC作业存储:
     通过调整其quartz.properties属性文件,持久化任务调度信息
     使用数据库保存任务调度信息后,即使系统崩溃后重新启动,任务的调度信息将得到恢复

1、RAMJobStore配置

#设置调度器的实例名
org.quartz.scheduler.instanceName: vpnOpenScheduler
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
# 指定多少个工作者线程被创建用来处理 Job
org.quartz.threadPool.threadCount: 10
# 设置工作者线程的优先级(最大值10,最小值1,常用值5)
org.quartz.threadPool.threadPriority: 5
# 加载任务代码的ClassLoader是否从外部继承
org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread: true

org.quartz.jobStore.misfireThreshold: 60000

# 默认配置,数据保存到内存(调度程序信息是存储在被分配给JVM的内存里面,运行速度快)
org.quartz.jobStore.class: org.quartz.simpl.RAMJobStore

2、JDBC作业存储

 

#调度器的实例名(instanceName)
org.quartz.scheduler.instanceName = AIJobServerScheduler
#设置调度器的实例ID (instanceId)如果使用集群,instanceId必须唯一,设置成AUTO
org.quartz.scheduler.instanceId = AUTO

org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 5
org.quartz.threadPool.threadPriority = 5

#是否使用集群(如果项目只部署到 一台服务器,就不用了)
org.quartz.jobStore.isClustered = true  
org.quartz.jobStore.clusterCheckinInterval = 20000 

org.quartz.jobStore.misfireThreshold = 60000
# 持久化配置(存储方式使用JobStoreTX,也就是数据库)
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
# 驱动器方言 数据库平台
org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.StdJDBCDelegate

#数据库中quartz表的表名前缀
org.quartz.jobStore.tablePrefix = QRTZ_

#============================================================================
# Configure Datasources配置数据源(可被覆盖,如果在schedulerFactoryBean指定数据源)
#============================================================================
org.quartz.dataSource.aiJobServer.driver = com.mysql.jdbc.Driver
org.quartz.dataSource.aiJobServer.URL = jdbc:mysql://XX.XX.XX.XX:XXXX/trunk?useUnicode=true&characterEncoding=utf8
org.quartz.dataSource.aiJobServer.user = rd
org.quartz.dataSource.aiJobServer.password = rd
org.quartz.dataSource.aiJobServer.maxConnections = 10  
#数据库别名 随便取
org.quartz.jobStore.dataSource = aiJobServer


四、Java实现代码

/**
*初始化定时任务
*/
public class VpnMplsOpenInit {
    public static void init(){
        
        
		
		//启动日报、周报、月报定时任务
        //scheduler配置的路径.properties
		String myJobSchedulerPath = SpringContextUtils.getBean("vpnOpenQuartz").toString();
		
		String hourStrDay = 3
		String minStrDay = 0
		Integer hourDay = 0;
		Integer minDay = 0;
		
		String weekStrWeek = IPNetHelper.getConfigProperties("RESOURCE_STATISTICS_WEEK_WEEK");
		String hourStrWeek = IPNetHelper.getConfigProperties("RESOURCE_STATISTICS_WEEK_HOUR");
		String minStrWeek = IPNetHelper.getConfigProperties("RESOURCE_STATISTICS_WEEK_MIN");
		Integer week = 0;
		Integer hourWeek = 0;
		Integer minWeek = 0;
		
		
		String monthStrMonth = IPNetHelper.getConfigProperties("RESOURCE_STATISTICS_MONTH_MONTH");
		String hourStrMonth = IPNetHelper.getConfigProperties("RESOURCE_STATISTICS_MONTH_HOUR");
		String minStrMonth = IPNetHelper.getConfigProperties("RESOURCE_STATISTICS_MONTH_MIN");
		Integer month = 0;
		Integer hourMonth = 0;
		Integer minMonth = 0;
		//周报是否执行
		boolean falgMonth = true;
		try {
            //创建调度器
			SchedulerFactory sf = new StdSchedulerFactory(myJobSchedulerPath);
			Scheduler scheduler = sf.getScheduler();
			Date startDate = null;
			if(falgDay){
				log.info("资源统计创建日报定时任务开始");
				//创建日报quart的任务信息对象
				JobDetail myJobDay = newJob(ResourceStatisticsDayJob.class).withIdentity(ResourceStatisticsDayJob, ResourceStatisticsDayJob + "-JobGroup").build();
				
				//设置触发器
				Trigger triggerDay = newTrigger().withIdentity(ResourceStatisticsDayJob, ResourceStatisticsDayJob + "-TriggerGroup").
				 withSchedule(dailyAtHourAndMinute(hourDay, minDay)).build();
				
				startDate = scheduler.scheduleJob(myJobDay, triggerDay);
				log.info("资源统计创建日报定时任务开始");
			}
			
			if(falgWeek){
				log.info("资源统计创建周报定时任务开始");
				//创建日报quart的任务信息对象
				JobDetail myJobWeek = newJob(ResourceStatisticsWeekJob.class).withIdentity(ResourceStatisticsWeekJob, ResourceStatisticsWeekJob + "-JobGroup").build();
				
				//设置触发器
				Trigger triggerWeek = newTrigger().withIdentity(ResourceStatisticsWeekJob, ResourceStatisticsWeekJob + "-TriggerGroup").
				 withSchedule(weeklyOnDayAndHourAndMinute(week,hourWeek, minWeek)).build();
				
				startDate = scheduler.scheduleJob(myJobWeek, triggerWeek);
				log.info("资源统计创建周报定时任务开始");
			}
			
			if(falgMonth){
				log.info("资源统计创建月报定时任务开始");
				//创建日报quart的任务信息对象
				JobDetail myJobMonth = newJob(ResourceStatisticsMonthJob.class).withIdentity(CResourceStatisticsMonthJob, ResourceStatisticsMonthJob + "-JobGroup").build();
				
				//设置触发器
				Trigger triggerMonth = newTrigger().withIdentity(ResourceStatisticsMonthJob, ResourceStatisticsMonthJob + "-TriggerGroup").
				 withSchedule(monthlyOnDayAndHourAndMinute(month,hourMonth, minMonth)).build();
				
				startDate = scheduler.scheduleJob(myJobMonth, triggerMonth);
				log.info("资源统计创建月报定时任务开始");
			}
			if(falgDay || falgWeek || falgMonth){
				scheduler.start();
			}
			log.info("资源统计日报、周报、月报任务启动成功,任务定时时间: " + startDate);
		} catch (SchedulerException e) {
			log.error("资源统计日报、周报、月报任务启动失败, 创建任务异常: ", e);
		}
	
    }
}


/**
*具体定时任务实现类
*/
public class ResourceStatisticsDayJob implements org.quartz.Job {

	/**
	 * 执行日报
	 * 
	 */
	public void execute(JobExecutionContext context) throws JobExecutionException {
        IServiceInterfaceApplyRemainDayModifyService service = 
        	(IServiceInterfaceApplyRemainDayModifyService)SpringContextUtils
        	.getBean("serviceInterfaceApplyRemainDayModifyServiceImpl");
		service.modifyRemainDay();
	}
}

 

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Quartz整合Spring Boot中,可以通过读取配置文件来配置Quartz的属性。具体步骤如下: 1. 在Spring Boot的配置文件(如application.properties或application.yml)中添加Quartz的相关配置信息。例如,可以配置Quartz的调度线程数、线程优先级、作业存储方式等。可以参考引用中提供的源码链接来查看具体的配置文件。 2. 在Spring Boot应用程序的启动类上使用`@EnableScheduling`注解开启定时任务。 3. 在需要执行定时任务的方法上使用`@Scheduled`注解,并指定定时任务的达式或固定时间间隔。这些注解和配置可以让Spring Boot自动创建和管理Quartz的调度器和作业。 需要注意的是,Quartz的配置和作业的定义并不需要额外的代码来读取配置文件。Spring Boot会自动将配置文件中的配置项注入到相关的Quartz对象中,从而实现整合。因此,只需要在配置文件中正确设置Quartz相关的属性即可。 总而言之,通过在Spring Boot的配置文件中配置Quartz的属性,并在启动类和定时任务方法上使用相应的注解,就可以实现Quartz和Spring Boot的整合,并读取配置文件来配置Quartz。这样就可以方便地实现定时任务的管理和调度。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SpringBoot 整合 Quartz](https://blog.csdn.net/weixin_48220189/article/details/128645014)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [SpringBoot整合Quartz](https://blog.csdn.net/weixin_38192427/article/details/121111677)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值