From 1a4046e7f566146b4d66ab702228703733625f38 Mon Sep 17 00:00:00 2001 From: Glenruben Larsen Date: Thu, 21 Dec 2023 11:03:45 +0100 Subject: [PATCH 1/3] Revert "[MIM-1707] Wrap most cron jobs in isMaster so no duplicate work is done (#2318)" This reverts commit b827f957be25cf53d1de4aca20e893a4d2ee65a2. --- src/main/resources/lib/ssb/cron/cron.ts | 258 ++++++++++++------------ 1 file changed, 129 insertions(+), 129 deletions(-) diff --git a/src/main/resources/lib/ssb/cron/cron.ts b/src/main/resources/lib/ssb/cron/cron.ts index bed89d660..2b84a9ef1 100644 --- a/src/main/resources/lib/ssb/cron/cron.ts +++ b/src/main/resources/lib/ssb/cron/cron.ts @@ -156,27 +156,20 @@ export function runOnMasterOnly(task: () => void): void { export function setupCronJobs(): void { run(createUserContext, setupCronJobUser) - // clear specific cache once an hour - const clearCacheCron: string = - app.config && app.config['ssb.cron.clearCacheCron'] ? app.config['ssb.cron.clearCacheCron'] : '01 * * * *' + // setup dataquery cron job + const dataqueryCron: string = + app.config && app.config['ssb.cron.dataquery'] ? app.config['ssb.cron.dataquery'] : '0 15 * * *' schedule({ - name: 'clear cache', - cron: clearCacheCron, + name: 'Data from datasource endpoints', + cron: dataqueryCron, callback: () => { - clearPartFromPartCache('kpiCalculator') - clearPartFromPartCache('pifCalculator') - clearPartFromPartCache('bkibolCalculator') - clearPartFromPartCache('husleieCalculator') - clearPartFromPartCache('omStatistikken') - clearPartFromPartCache('releasedStatistics') - clearPartFromPartCache('upcomingReleases') - clearPartFromPartCache('articleList') - clearPartFromPartCache('relatedFactPage') - clearPartFromPartCache('archiveAllPublications-nb') - clearPartFromPartCache('archiveAllPublications-en') + libScheduleTestLog('dataqueryCronTest', dataqueryCron) + runOnMasterOnly(job) }, context: cronContext, }) + // using config in https://github.com/statisticsnorway/mimir-config/blob/master/prod/mimir.cfg as base + libScheduleTest({ name: 'dataqueryCronTest', cron: '03 08 * * *', timeZone: 'Europe/Oslo' }, dataqueryCron) // clear calculator parts cache cron const clearCalculatorPartsCacheCron: string = @@ -196,133 +189,140 @@ export function setupCronJobs(): void { }, context: cronContext, }) + libScheduleTest( + { name: 'clearCalculatorCronTest', cron: '15 08 * * *', timeZone: 'Europe/Oslo' }, + clearCalculatorPartsCacheCron + ) - if (isMaster()) { - // setup dataquery cron job - const dataqueryCron: string = - app.config && app.config['ssb.cron.dataquery'] ? app.config['ssb.cron.dataquery'] : '0 15 * * *' - schedule({ - name: 'Data from datasource endpoints', - cron: dataqueryCron, - callback: () => { - libScheduleTestLog('dataqueryCronTest', dataqueryCron) - job() - }, - context: cronContext, - }) - // using config in https://github.com/statisticsnorway/mimir-config/blob/master/prod/mimir.cfg as base - libScheduleTest({ name: 'dataqueryCronTest', cron: '03 08 * * *', timeZone: 'Europe/Oslo' }, dataqueryCron) + // and setup a cron for periodic executions in the future + const statregCron: string = + app.config && app.config['ssb.cron.statreg'] ? app.config['ssb.cron.statreg'] : '30 14 * * *' + schedule({ + name: 'StatReg Periodic Refresh', + cron: statregCron, + callback: () => { + libScheduleTestLog('statregRefreshCronTest', statregCron) + runOnMasterOnly(statRegJob) + }, + context: cronContext, + }) + libScheduleTest({ name: 'statregRefreshCronTest', cron: '05 8 * * *', timeZone: 'Europe/Oslo' }, statregCron) - // and setup a cron for periodic executions in the future - const statregCron: string = - app.config && app.config['ssb.cron.statreg'] ? app.config['ssb.cron.statreg'] : '30 14 * * *' - schedule({ - name: 'StatReg Periodic Refresh', - cron: statregCron, - callback: () => { - libScheduleTestLog('statregRefreshCronTest', statregCron) - statRegJob() - }, - context: cronContext, - }) - libScheduleTest({ name: 'statregRefreshCronTest', cron: '05 8 * * *', timeZone: 'Europe/Oslo' }, statregCron) + // Update repo no.ssb.statistic.variant + const updateStatisticRepoCron: string = + app.config && app.config['ssb.cron.updateStatisticRepo'] ? app.config['ssb.cron.updateStatisticRepo'] : '0 7 * * *' - // Update repo no.ssb.statistic.variant - const updateStatisticRepoCron: string = - app.config && app.config['ssb.cron.updateStatisticRepo'] - ? app.config['ssb.cron.updateStatisticRepo'] - : '0 7 * * *' + schedule({ + name: 'Update no.ssb.statistics Repo', + cron: updateStatisticRepoCron, + callback: () => { + libScheduleTestLog('statregUpdateCronTest', updateStatisticRepoCron) + runOnMasterOnly(createOrUpdateStatisticsRepo) + }, + context: cronContext, + }) + libScheduleTest( + { name: 'statregUpdateCronTest', cron: '0 8 * * *', timeZone: 'Europe/Oslo' }, + updateStatisticRepoCron + ) - schedule({ - name: 'Update no.ssb.statistics Repo', - cron: updateStatisticRepoCron, - callback: () => { - libScheduleTestLog('statregUpdateCronTest', updateStatisticRepoCron) - createOrUpdateStatisticsRepo() - }, - context: cronContext, - }) - libScheduleTest( - { name: 'statregUpdateCronTest', cron: '0 8 * * *', timeZone: 'Europe/Oslo' }, - updateStatisticRepoCron - ) + const deleteExpiredEventLogCron: string = + app.config && app.config['ssb.cron.deleteLogs'] ? app.config['ssb.cron.deleteLogs'] : '45 13 * * *' + schedule({ + name: 'Delete expired event logs for queries', + cron: deleteExpiredEventLogCron, + callback: () => { + libScheduleTestLog('deleteExpireCronTest', deleteExpiredEventLogCron) + runOnMasterOnly(deleteExpiredEventLogsForQueries) + }, + context: cronContext, + }) + libScheduleTest( + { name: 'deleteExpireCronTest', cron: '20 15 * * *', timeZone: 'Europe/Oslo' }, + deleteExpiredEventLogCron + ) - const deleteExpiredEventLogCron: string = - app.config && app.config['ssb.cron.deleteLogs'] ? app.config['ssb.cron.deleteLogs'] : '45 13 * * *' + if (app.config && app.config['ssb.mock.enable'] === 'true') { + const updateUnpublishedMockCron: string = + app.config && app.config['ssb.cron.updateUnpublishedMock'] + ? app.config['ssb.cron.updateUnpublishedMock'] + : '0 04 * * *' schedule({ - name: 'Delete expired event logs for queries', - cron: deleteExpiredEventLogCron, - callback: () => { - libScheduleTestLog('deleteExpireCronTest', deleteExpiredEventLogCron) - deleteExpiredEventLogsForQueries() - }, + name: 'Update unpublished mock tbml', + cron: updateUnpublishedMockCron, + callback: () => runOnMasterOnly(updateUnpublishedMockTbml), context: cronContext, }) - libScheduleTest( - { name: 'deleteExpireCronTest', cron: '20 15 * * *', timeZone: 'Europe/Oslo' }, - deleteExpiredEventLogCron - ) + } - if (app.config && app.config['ssb.mock.enable'] === 'true') { - const updateUnpublishedMockCron: string = - app.config && app.config['ssb.cron.updateUnpublishedMock'] - ? app.config['ssb.cron.updateUnpublishedMock'] - : '0 04 * * *' - schedule({ - name: 'Update unpublished mock tbml', - cron: updateUnpublishedMockCron, - callback: () => updateUnpublishedMockTbml(), - context: cronContext, - }) - } + // push news to rss feed + const pushRssNewsCron: string = + app.config && app.config['ssb.cron.pushRssNews'] ? app.config['ssb.cron.pushRssNews'] : '02 06 * * *' + schedule({ + name: 'Push RSS news', + cron: pushRssNewsCron, + callback: () => { + libScheduleTestLog('pushRssNewsCronTest', pushRssNewsCron) + runOnMasterOnly(pushRssNewsJob) + }, + context: cronContext, + }) + libScheduleTest({ name: 'pushRssNewsCronTest', cron: '01 08 * * *', timeZone: 'Europe/Oslo' }, pushRssNewsCron) - // push news to rss feed - const pushRssNewsCron: string = - app.config && app.config['ssb.cron.pushRssNews'] ? app.config['ssb.cron.pushRssNews'] : '02 06 * * *' - schedule({ - name: 'Push RSS news', - cron: pushRssNewsCron, - callback: () => { - libScheduleTestLog('pushRssNewsCronTest', pushRssNewsCron) - pushRssNewsJob() - }, - context: cronContext, - }) - libScheduleTest({ name: 'pushRssNewsCronTest', cron: '01 08 * * *', timeZone: 'Europe/Oslo' }, pushRssNewsCron) + // clear specific cache once an hour + const clearCacheCron: string = + app.config && app.config['ssb.cron.clearCacheCron'] ? app.config['ssb.cron.clearCacheCron'] : '01 * * * *' + schedule({ + name: 'clear cache', + cron: clearCacheCron, + callback: () => { + clearPartFromPartCache('kpiCalculator') + clearPartFromPartCache('pifCalculator') + clearPartFromPartCache('bkibolCalculator') + clearPartFromPartCache('husleieCalculator') + clearPartFromPartCache('omStatistikken') + clearPartFromPartCache('releasedStatistics') + clearPartFromPartCache('upcomingReleases') + clearPartFromPartCache('articleList') + clearPartFromPartCache('relatedFactPage') + clearPartFromPartCache('archiveAllPublications-nb') + clearPartFromPartCache('archiveAllPublications-en') + }, + context: cronContext, + }) - // Update SDDS tables - const updateSDDSTablesCron: string = - app.config && app.config['ssb.cron.updateSDDSTables'] ? app.config['ssb.cron.updateSDDSTables'] : '01 09 * * *' - schedule({ - name: 'Update SDDS tables', - cron: updateSDDSTablesCron, - callback: () => { - libScheduleTestLog('updateSDDSCronTest', updateSDDSTablesCron) - updateSDDSTables() - }, - context: cronContext, - }) - libScheduleTest({ name: 'updateSDDSCronTest', cron: '01 09 * * *', timeZone: 'Europe/Oslo' }, updateSDDSTablesCron) + // Update SDDS tables + const updateSDDSTablesCron: string = + app.config && app.config['ssb.cron.updateSDDSTables'] ? app.config['ssb.cron.updateSDDSTables'] : '01 09 * * *' + schedule({ + name: 'Update SDDS tables', + cron: updateSDDSTablesCron, + callback: () => { + libScheduleTestLog('updateSDDSCronTest', updateSDDSTablesCron) + runOnMasterOnly(updateSDDSTables) + }, + context: cronContext, + }) + libScheduleTest({ name: 'updateSDDSCronTest', cron: '01 09 * * *', timeZone: 'Europe/Oslo' }, updateSDDSTablesCron) - const datasetPublishCron: string = - app.config && app.config['ssb.cron.publishDataset'] ? app.config['ssb.cron.publishDataset'] : '50 05 * * *' + const datasetPublishCron: string = + app.config && app.config['ssb.cron.publishDataset'] ? app.config['ssb.cron.publishDataset'] : '50 05 * * *' - log.info('Run old datasetPublishCron cron-library') - // publish dataset cron job - schedule({ - name: 'Dataset publish', - cron: datasetPublishCron, - callback: () => { - libScheduleTestLog('datasetPublishCronTest', datasetPublishCron) - publishDataset() - }, - context: cronContext, - }) - libScheduleTest( - { name: 'datasetPublishCronTest', cron: '50 07 * * *', timeZone: 'Europe/Oslo' }, - datasetPublishCron - ) + log.info('Run old datasetPublishCron cron-library') + // publish dataset cron job + schedule({ + name: 'Dataset publish', + cron: datasetPublishCron, + callback: () => { + libScheduleTestLog('datasetPublishCronTest', datasetPublishCron) + runOnMasterOnly(publishDataset) + }, + context: cronContext, + }) + libScheduleTest({ name: 'datasetPublishCronTest', cron: '50 07 * * *', timeZone: 'Europe/Oslo' }, datasetPublishCron) + // Task + if (isMaster()) { const timezone: string = app.config && app.config['ssb.cron.timezone'] ? app.config['ssb.cron.timezone'] : 'Europe/Oslo' From 14d32f332588c9490c12a4904aa089af535bc870 Mon Sep 17 00:00:00 2001 From: Glenruben Larsen Date: Thu, 21 Dec 2023 14:33:38 +0100 Subject: [PATCH 2/3] Also remove running tests of scheduler lib --- src/main/resources/lib/ssb/cron/cron.ts | 34 ++++++++++++------------- 1 file changed, 17 insertions(+), 17 deletions(-) diff --git a/src/main/resources/lib/ssb/cron/cron.ts b/src/main/resources/lib/ssb/cron/cron.ts index 2b84a9ef1..846bf4523 100644 --- a/src/main/resources/lib/ssb/cron/cron.ts +++ b/src/main/resources/lib/ssb/cron/cron.ts @@ -169,7 +169,7 @@ export function setupCronJobs(): void { context: cronContext, }) // using config in https://github.com/statisticsnorway/mimir-config/blob/master/prod/mimir.cfg as base - libScheduleTest({ name: 'dataqueryCronTest', cron: '03 08 * * *', timeZone: 'Europe/Oslo' }, dataqueryCron) + // libScheduleTest({ name: 'dataqueryCronTest', cron: '03 08 * * *', timeZone: 'Europe/Oslo' }, dataqueryCron) // clear calculator parts cache cron const clearCalculatorPartsCacheCron: string = @@ -189,10 +189,10 @@ export function setupCronJobs(): void { }, context: cronContext, }) - libScheduleTest( - { name: 'clearCalculatorCronTest', cron: '15 08 * * *', timeZone: 'Europe/Oslo' }, - clearCalculatorPartsCacheCron - ) + // libScheduleTest( + // { name: 'clearCalculatorCronTest', cron: '15 08 * * *', timeZone: 'Europe/Oslo' }, + // clearCalculatorPartsCacheCron + // ) // and setup a cron for periodic executions in the future const statregCron: string = @@ -206,7 +206,7 @@ export function setupCronJobs(): void { }, context: cronContext, }) - libScheduleTest({ name: 'statregRefreshCronTest', cron: '05 8 * * *', timeZone: 'Europe/Oslo' }, statregCron) + // libScheduleTest({ name: 'statregRefreshCronTest', cron: '05 8 * * *', timeZone: 'Europe/Oslo' }, statregCron) // Update repo no.ssb.statistic.variant const updateStatisticRepoCron: string = @@ -221,10 +221,10 @@ export function setupCronJobs(): void { }, context: cronContext, }) - libScheduleTest( - { name: 'statregUpdateCronTest', cron: '0 8 * * *', timeZone: 'Europe/Oslo' }, - updateStatisticRepoCron - ) + // libScheduleTest( + // { name: 'statregUpdateCronTest', cron: '0 8 * * *', timeZone: 'Europe/Oslo' }, + // updateStatisticRepoCron + // ) const deleteExpiredEventLogCron: string = app.config && app.config['ssb.cron.deleteLogs'] ? app.config['ssb.cron.deleteLogs'] : '45 13 * * *' @@ -237,10 +237,10 @@ export function setupCronJobs(): void { }, context: cronContext, }) - libScheduleTest( - { name: 'deleteExpireCronTest', cron: '20 15 * * *', timeZone: 'Europe/Oslo' }, - deleteExpiredEventLogCron - ) + // libScheduleTest( + // { name: 'deleteExpireCronTest', cron: '20 15 * * *', timeZone: 'Europe/Oslo' }, + // deleteExpiredEventLogCron + // ) if (app.config && app.config['ssb.mock.enable'] === 'true') { const updateUnpublishedMockCron: string = @@ -267,7 +267,7 @@ export function setupCronJobs(): void { }, context: cronContext, }) - libScheduleTest({ name: 'pushRssNewsCronTest', cron: '01 08 * * *', timeZone: 'Europe/Oslo' }, pushRssNewsCron) + // libScheduleTest({ name: 'pushRssNewsCronTest', cron: '01 08 * * *', timeZone: 'Europe/Oslo' }, pushRssNewsCron) // clear specific cache once an hour const clearCacheCron: string = @@ -303,7 +303,7 @@ export function setupCronJobs(): void { }, context: cronContext, }) - libScheduleTest({ name: 'updateSDDSCronTest', cron: '01 09 * * *', timeZone: 'Europe/Oslo' }, updateSDDSTablesCron) + // libScheduleTest({ name: 'updateSDDSCronTest', cron: '01 09 * * *', timeZone: 'Europe/Oslo' }, updateSDDSTablesCron) const datasetPublishCron: string = app.config && app.config['ssb.cron.publishDataset'] ? app.config['ssb.cron.publishDataset'] : '50 05 * * *' @@ -319,7 +319,7 @@ export function setupCronJobs(): void { }, context: cronContext, }) - libScheduleTest({ name: 'datasetPublishCronTest', cron: '50 07 * * *', timeZone: 'Europe/Oslo' }, datasetPublishCron) + // libScheduleTest({ name: 'datasetPublishCronTest', cron: '50 07 * * *', timeZone: 'Europe/Oslo' }, datasetPublishCron) // Task if (isMaster()) { From 2761ef2046688df5ff2c55dd0b76ee6c96adab3d Mon Sep 17 00:00:00 2001 From: GitHub Actions Bot <> Date: Thu, 21 Dec 2023 14:09:48 +0000 Subject: [PATCH 3/3] Update version number to v2.1.1 --- gradle.properties | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle.properties b/gradle.properties index 55ae5fd58..0d374a030 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,6 +1,6 @@ # Gradle Project settings projectName = mimir -version = 2.1.0 +version = 2.1.1 # XP App values appDisplayName = Mimir application