Нужна помощь с очень простым вопросом (на самом деле я очень новичок в Quartz Scheduling только сегодня начал учиться у https://flylib.com/books/en/2.65.1/, так как один из проектов миграции, над которым я работаю, использует это.)
Постановка задачи-
1) Мы используем JobStoreCMT с двумя источниками данных WebLogic. Действительно ли нам нужны таблицы Persistent Job Store (эти базовые таблицы 12 кварцевых планировщиков)?
2) Запустил QuartzScheduler, но не вижу вставок/обновлений в JobStore Tables, что-то здесь не так?
3) Перед запуском Quartz Scheduler Job нужно ли нам выполнить какую-либо настройку в таблицах хранилища постоянных заданий кварца, таких как qrtz_job_details?
4) Любые другие конфигурации, если это необходимо.
Быстрая помощь будет высоко оценена.
Я также начал пользоваться библиотекой примерно месяц назад и предлагаю вам ознакомиться с официальной документацией. Они действительно помогают
1) JobStoreCMT — это реализация постоянного хранилища заданий. так что ответ да, вам нужны кварцевые столы Из документов http://www.quartz-scheduler.org/documentation/2.3.1-SNAPSHOT/introduction.html
Transactions
Quartz can participate in JTA transactions, via the use of JobStoreCMT (a subclass of JDBCJobStore).
2) Если вы не запланируете никаких заданий, новых записей не будет. Также вы можете неправильно настроить кварцевый планировщик. При инициализации вам необходимо, например, предоставить файл свойств кварца с указанием местоположения ваших кварцевых таблиц. Документы http://www.quartz-scheduler.org/documentation/2.3.1-SNAPSHOT/quick-start-guide.html#the-properties-file
Как правило, когда вы запускаете приложение, у вас будет одна запись с идентификатором планировщика в таблице кварцевого планировщика. После того, как вы создали задание с триггером, вы увидите информацию в таблице заданий и в таблице триггеров.
3) вручную с кварт столами ничего делать не надо, с квартом нужно взаимодействовать только через планировщик апи Проверьте эти уроки, чтобы начать http://www.quartz-scheduler.org/documentation/2.4.0-SNAPSHOT/tutorials/index.html
4) для базового использования дополнительная настройка не требуется
Кроме того, нужно ли нам вставлять значения в таблицуquarts_locks? Ниже приведен файл свойств, который я использую: =true org.quartz.jobStore.class=org.quartz.impl.jdbcjobstore.JobStoreCMT org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.oracle.weblogic.WebLogicOracleDelegate Пожалуйста, предложите что может быть возможной причиной проблемы, что планировщик не работает должным образом.
Вы пытались установить для автозапуска свойства планировщика значение true? Или использовать scheduler.start()? Также при запуске вашего приложения в логах должна быть строка с подробной информацией о планировщике кварца (параметры, которые использует кварц)
На самом деле в рамках проекта миграции нам не разрешено изменять код. Это свойство, о котором вы говорите - org.quartz.scheduler.threadsInheritContextClassLoaderOfInitializer = true Также я узнал, что существует известная проблема кварцевого планировщика, заключающаяся в том, что он заходит в тупик, когда мы работаем с Oracle RAC env. (QTZ-149), у вас есть какие-нибудь идеи по этому поводу?
Единственная проблема, с которой я сейчас сталкиваюсь, заключается в том, что ни статические, ни динамические планировщики не запускаются, когда я использую CMTJobStore. Кварц.log также не имеет ошибок, я проверил консоль WebLogic на наличие дампа потока, но ни один поток не застрял. Также у меня есть индексы на всех кварцевых столах. Все отлично работает с RAMJobStore. Это связано с каким-либо параметром в базе данных Oracle? У меня есть job_queue_processes=10 в базе данных. <br> Далее я проверил таблицы кварца, и в следующих таблицах нет записей: QUARTZ_CRON_TRIGGERS, QUARTZ_FIRED_TRIGGERS, QUARTZ_JOB_DETAILS, QUARTZ_SCHEDULER_STATE, QUARTZ_TRIGGERS.