Commit a6c7263d authored by Stan Hu's avatar Stan Hu

Disable all non-Geo related Sidekiq-cron workers on the secondary

Most of the workers need to update the database, which fails
miserably on the secondary.
parent cbc7db9b
...@@ -3,7 +3,6 @@ class HistoricalDataWorker ...@@ -3,7 +3,6 @@ class HistoricalDataWorker
include CronjobQueue include CronjobQueue
def perform def perform
return if Gitlab::Geo.secondary?
return if License.current.nil? || License.current&.trial? return if License.current.nil? || License.current&.trial?
HistoricalData.track! HistoricalData.track!
......
...@@ -3,8 +3,6 @@ class PruneOldEventsWorker ...@@ -3,8 +3,6 @@ class PruneOldEventsWorker
include CronjobQueue include CronjobQueue
def perform def perform
return if Gitlab::Geo.secondary?
# Contribution calendar shows maximum 12 months of events. # Contribution calendar shows maximum 12 months of events.
# Double nested query is used because MySQL doesn't allow DELETE subqueries # Double nested query is used because MySQL doesn't allow DELETE subqueries
# on the same table. # on the same table.
......
...@@ -3,8 +3,6 @@ class ScheduleUpdateUserActivityWorker ...@@ -3,8 +3,6 @@ class ScheduleUpdateUserActivityWorker
include CronjobQueue include CronjobQueue
def perform(batch_size = 500) def perform(batch_size = 500)
return if Gitlab::Geo.secondary?
Gitlab::UserActivities.new.each_slice(batch_size) do |batch| Gitlab::UserActivities.new.each_slice(batch_size) do |batch|
UpdateUserActivityWorker.perform_async(Hash[batch]) UpdateUserActivityWorker.perform_async(Hash[batch])
end end
......
...@@ -6,10 +6,6 @@ class UpdateAllMirrorsWorker ...@@ -6,10 +6,6 @@ class UpdateAllMirrorsWorker
LEASE_KEY = 'update_all_mirrors'.freeze LEASE_KEY = 'update_all_mirrors'.freeze
def perform def perform
# This worker requires updating the database state, which we can't
# do on a Geo secondary
return if Gitlab::Geo.secondary?
lease_uuid = try_obtain_lease lease_uuid = try_obtain_lease
return unless lease_uuid return unless lease_uuid
......
...@@ -3,8 +3,6 @@ class UpdateUserActivityWorker ...@@ -3,8 +3,6 @@ class UpdateUserActivityWorker
include DedicatedSidekiqQueue include DedicatedSidekiqQueue
def perform(pairs) def perform(pairs)
return if Gitlab::Geo.secondary?
pairs = cast_data(pairs) pairs = cast_data(pairs)
ids = pairs.keys ids = pairs.keys
conditions = 'WHEN id = ? THEN ? ' * ids.length conditions = 'WHEN id = ? THEN ? ' * ids.length
......
...@@ -83,27 +83,40 @@ module Gitlab ...@@ -83,27 +83,40 @@ module Gitlab
end end
def self.configure_primary_jobs! def self.configure_primary_jobs!
PRIMARY_JOBS.each { |job| self.send(job).try(:enable!) } self.enable_all_cron_jobs!
SECONDARY_JOBS.each { |job| self.send(job).try(:disable!) } SECONDARY_JOBS.each { |job| self.send(job).try(:disable!) }
end end
def self.configure_secondary_jobs! def self.configure_secondary_jobs!
PRIMARY_JOBS.each { |job| self.send(job).try(:disable!) } self.disable_all_cron_jobs!
SECONDARY_JOBS.each { |job| self.send(job).try(:enable!) } SECONDARY_JOBS.each { |job| self.send(job).try(:enable!) }
end end
def self.disable_all_jobs! def self.disable_all_geo_jobs!
PRIMARY_JOBS.each { |job| self.send(job).try(:disable!) } PRIMARY_JOBS.each { |job| self.send(job).try(:disable!) }
SECONDARY_JOBS.each { |job| self.send(job).try(:disable!) } SECONDARY_JOBS.each { |job| self.send(job).try(:disable!) }
end end
def self.disable_all_cron_jobs!
self.cron_jobs.select(&:enabled?).each { |job| job.disable! }
end
def self.enable_all_cron_jobs!
self.cron_jobs.reject(&:enabled?).each { |job| job.enable! }
end
def self.cron_jobs
Sidekiq::Cron::Job.all
end
def self.configure_cron_jobs! def self.configure_cron_jobs!
if self.primary_role_enabled? if self.primary_role_enabled?
self.configure_primary_jobs! self.configure_primary_jobs!
elsif self.secondary_role_enabled? elsif self.secondary_role_enabled?
self.configure_secondary_jobs! self.configure_secondary_jobs!
else else
self.disable_all_jobs! self.enable_all_cron_jobs!
self.disable_all_geo_jobs!
end end
end end
......
...@@ -122,15 +122,17 @@ describe Gitlab::Geo, lib: true do ...@@ -122,15 +122,17 @@ describe Gitlab::Geo, lib: true do
describe '.configure_cron_jobs!' do describe '.configure_cron_jobs!' do
def init_cron_job(job_name, class_name) def init_cron_job(job_name, class_name)
Sidekiq::Cron::Job.create( job = Sidekiq::Cron::Job.new(
name: job_name, name: job_name,
cron: '0 * * * *', cron: '0 * * * *',
class: class_name class: class_name
) )
job.enable!
end end
before(:all) do before(:all) do
jobs = %w(geo_bulk_notify_worker geo_repository_sync_worker geo_file_download_dispatch_worker) jobs = %w(ldap_test geo_bulk_notify_worker geo_repository_sync_worker geo_file_download_dispatch_worker)
jobs.each { |job| init_cron_job(job, job.camelize) } jobs.each { |job| init_cron_job(job, job.camelize) }
end end
...@@ -143,6 +145,7 @@ describe Gitlab::Geo, lib: true do ...@@ -143,6 +145,7 @@ describe Gitlab::Geo, lib: true do
expect(described_class.bulk_notify_job).to be_enabled expect(described_class.bulk_notify_job).to be_enabled
expect(described_class.repository_sync_job).not_to be_enabled expect(described_class.repository_sync_job).not_to be_enabled
expect(described_class.file_download_job).not_to be_enabled expect(described_class.file_download_job).not_to be_enabled
expect(Sidekiq::Cron::Job.find('ldap_test')).to be_enabled
end end
it 'activates cron jobs for secondary' do it 'activates cron jobs for secondary' do
...@@ -151,6 +154,7 @@ describe Gitlab::Geo, lib: true do ...@@ -151,6 +154,7 @@ describe Gitlab::Geo, lib: true do
described_class.configure_cron_jobs! described_class.configure_cron_jobs!
expect(Sidekiq::Cron::Job.find('ldap_test')).not_to be_enabled
expect(described_class.bulk_notify_job).not_to be_enabled expect(described_class.bulk_notify_job).not_to be_enabled
expect(described_class.repository_sync_job).to be_enabled expect(described_class.repository_sync_job).to be_enabled
expect(described_class.file_download_job).to be_enabled expect(described_class.file_download_job).to be_enabled
...@@ -165,6 +169,21 @@ describe Gitlab::Geo, lib: true do ...@@ -165,6 +169,21 @@ describe Gitlab::Geo, lib: true do
expect(described_class.bulk_notify_job).not_to be_enabled expect(described_class.bulk_notify_job).not_to be_enabled
expect(described_class.repository_sync_job).not_to be_enabled expect(described_class.repository_sync_job).not_to be_enabled
expect(described_class.file_download_job).not_to be_enabled expect(described_class.file_download_job).not_to be_enabled
expect(Sidekiq::Cron::Job.find('ldap_test')).to be_enabled
end
it 'reactivates cron jobs when node turns off Geo' do
allow(described_class).to receive(:primary_role_enabled?).and_return(false)
allow(described_class).to receive(:secondary_role_enabled?).and_return(true)
described_class.configure_cron_jobs!
expect(Sidekiq::Cron::Job.find('ldap_test')).not_to be_enabled
allow(described_class).to receive(:primary_role_enabled?).and_return(false)
allow(described_class).to receive(:secondary_role_enabled?).and_return(false)
described_class.configure_cron_jobs!
expect(Sidekiq::Cron::Job.find('ldap_test')).to be_enabled
end end
end end
end end
...@@ -28,16 +28,6 @@ describe HistoricalDataWorker do ...@@ -28,16 +28,6 @@ describe HistoricalDataWorker do
end end
end end
context 'with a Geo secondary node' do
it 'does not track historical data' do
allow(Gitlab::Geo).to receive(:secondary?).and_return(true)
expect(HistoricalData).not_to receive(:track!)
subject.perform
end
end
context 'when there is not a license key' do context 'when there is not a license key' do
it 'does not track historical data' do it 'does not track historical data' do
License.destroy_all License.destroy_all
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment