QRTZ_FIRED_TRIGGERS 存儲與已觸發(fā)的 Trigger 相關的狀態(tài)信息,以及相聯(lián) Job的執(zhí)行信息QRTZ_PAUSED_TRIGGER_GRPS 存儲已暫停的 Trigger 組的信息
QRTZ_BLOG_TRIGGERS Trigger 作為 Blob 類型存儲(用于 Quartz 用戶用 JDBC創(chuàng)建他們自己定制的 Trigger 類型,JobStore 并不知道如何存儲實例的時候)
--------------------------------------------------------------------------------------------------
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狀態(tài),設置為ACQUIRED,如果設置為WAITING,則job不會觸發(fā)
trigger_cron:觸發(fā)器類型,使用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會定時讀取該表的信息判斷集群中每個實例的當前狀態(tài)
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
#容許的最大作業(yè)延長時間 org.quartz.jobStore.misfireThreshold = 60000
#ThreadPool 實現的類名 org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
#線程數量 org.quartz.threadPool.threadCount = 10
#線程優(yōu)先級 org.quartz.threadPool.threadPriority = 5
#自創(chuàng)建父線程 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
【注】:在J2EE工程中如果想用數據庫管理Quartz的相關信息,就一定要配置數據源,這是Quartz的要求。