quartz 數據庫表含義解釋

原文鏈接:https://blog.csdn.net/dqswuyundong/article/details/53084725

https://blog.csdn.net/dqswuyundong/article/details/53084725

 

一、表信息解析:

1.1.qrtz_blob_triggers : 以Blob 類型存儲的觸發器。 
1.2.qrtz_calendars:存放日曆信息, quartz可配置一個日曆來指定一個時間範圍。 
1.3.qrtz_cron_triggers:存放cron類型的觸發器。 
1.4.qrtz_fired_triggers:存放已觸發的觸發器。 
1.5.qrtz_job_details:存放一個jobDetail信息。 
1.6.qrtz_job_listeners:job**監聽器**。 
1.7.qrtz_locks: 存儲程序的悲觀鎖的信息(假如使用了悲觀鎖)。 
1.8.qrtz_paused_trigger_graps:存放暫停掉的觸發器。 
1.9.qrtz_scheduler_state:調度器狀態。 
1.10.qrtz_simple_triggers:簡單觸發器的信息。 
1.11.qrtz_trigger_listeners:觸發器監聽器。 
1.12.qrtz_triggers:觸發器的基本信息。

二、Quartz的觸發時間的配置的三種方式:

2.1.cron 方式:採用cronExpression表達式配置時間。 
2.2.simple 方式:和JavaTimer差不多,可以指定一個開始時間和結束時間外加一個循環時間。 
2.3.calendars 方式:可以和cron配合使用,用cron表達式指定一個觸發時間規律,用calendar指定一個範圍。

注意:cron方式需要用到的4張數據表: 
qrtz_triggers,qrtz_cron_triggers,qrtz_fired_triggers,qrtz_job_details。

 

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

 

【注】:在J2EE工程中如果想用數據庫管理Quartz的相關信息,就一定要配置數據源,這是Quartz的要求。

 

 

轉載:http://blog.csdn.net/tengdazhang770960436/article/details/51019291

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章