Commit 8d17c4da authored by Kamil Trzciński's avatar Kamil Trzciński

Properly handle `sidekiq` skip

Transform `CancelledError` into `JobRetry::Skip`
parent cb193cd6
...@@ -28,12 +28,13 @@ if Rails.env.development? ...@@ -28,12 +28,13 @@ if Rails.env.development?
end end
enable_json_logs = Gitlab.config.sidekiq.log_format == 'json' enable_json_logs = Gitlab.config.sidekiq.log_format == 'json'
enable_sidekiq_monitor = ENV.fetch("SIDEKIQ_MONITOR_WORKER", 0).to_i.nonzero?
Sidekiq.configure_server do |config| Sidekiq.configure_server do |config|
config.redis = queues_config_hash config.redis = queues_config_hash
config.server_middleware do |chain| config.server_middleware do |chain|
chain.add Gitlab::SidekiqMiddleware::Monitor chain.add Gitlab::SidekiqMiddleware::Monitor if enable_sidekiq_monitor
chain.add Gitlab::SidekiqMiddleware::Metrics if Settings.monitoring.sidekiq_exporter chain.add Gitlab::SidekiqMiddleware::Metrics if Settings.monitoring.sidekiq_exporter
chain.add Gitlab::SidekiqMiddleware::ArgumentsLogger if ENV['SIDEKIQ_LOG_ARGUMENTS'] && !enable_json_logs chain.add Gitlab::SidekiqMiddleware::ArgumentsLogger if ENV['SIDEKIQ_LOG_ARGUMENTS'] && !enable_json_logs
chain.add Gitlab::SidekiqMiddleware::MemoryKiller if ENV['SIDEKIQ_MEMORY_KILLER_MAX_RSS'] chain.add Gitlab::SidekiqMiddleware::MemoryKiller if ENV['SIDEKIQ_MEMORY_KILLER_MAX_RSS']
...@@ -59,9 +60,7 @@ Sidekiq.configure_server do |config| ...@@ -59,9 +60,7 @@ Sidekiq.configure_server do |config|
# Sidekiq (e.g. in an initializer). # Sidekiq (e.g. in an initializer).
ActiveRecord::Base.clear_all_connections! ActiveRecord::Base.clear_all_connections!
if ENV.fetch("SIDEKIQ_MONITOR_WORKER", 0).to_i.nonzero? Gitlab::SidekiqMonitor.instance.start if enable_sidekiq_monitor
Gitlab::SidekiqMonitor.instance.start
end
end end
if enable_reliable_fetch? if enable_reliable_fetch?
......
...@@ -7,6 +7,9 @@ module Gitlab ...@@ -7,6 +7,9 @@ module Gitlab
Gitlab::SidekiqMonitor.instance.within_job(job['jid'], queue) do Gitlab::SidekiqMonitor.instance.within_job(job['jid'], queue) do
yield yield
end end
rescue Gitlab::SidekiqMonitor::CancelledError
# ignore retries
raise Sidekiq::JobRetry::Skip
end end
end end
end end
......
...@@ -30,7 +30,7 @@ module Gitlab ...@@ -30,7 +30,7 @@ module Gitlab
if cancelled?(jid) if cancelled?(jid)
Sidekiq.logger.warn( Sidekiq.logger.warn(
class: self.class, class: self.class.to_s,
action: 'run', action: 'run',
queue: queue, queue: queue,
jid: jid, jid: jid,
...@@ -62,7 +62,7 @@ module Gitlab ...@@ -62,7 +62,7 @@ module Gitlab
def start_working def start_working
Sidekiq.logger.info( Sidekiq.logger.info(
class: self.class, class: self.class.to_s,
action: 'start', action: 'start',
message: 'Starting Monitor Daemon' message: 'Starting Monitor Daemon'
) )
...@@ -74,7 +74,7 @@ module Gitlab ...@@ -74,7 +74,7 @@ module Gitlab
ensure ensure
Sidekiq.logger.warn( Sidekiq.logger.warn(
class: self.class, class: self.class.to_s,
action: 'stop', action: 'stop',
message: 'Stopping Monitor Daemon' message: 'Stopping Monitor Daemon'
) )
...@@ -94,7 +94,7 @@ module Gitlab ...@@ -94,7 +94,7 @@ module Gitlab
end end
rescue Exception => e # rubocop:disable Lint/RescueException rescue Exception => e # rubocop:disable Lint/RescueException
Sidekiq.logger.warn( Sidekiq.logger.warn(
class: self.class, class: self.class.to_s,
action: 'exception', action: 'exception',
message: e.message message: e.message
) )
...@@ -105,7 +105,7 @@ module Gitlab ...@@ -105,7 +105,7 @@ module Gitlab
def process_message(message) def process_message(message)
Sidekiq.logger.info( Sidekiq.logger.info(
class: self.class, class: self.class.to_s,
channel: NOTIFICATION_CHANNEL, channel: NOTIFICATION_CHANNEL,
message: 'Received payload on channel', message: 'Received payload on channel',
payload: message payload: message
...@@ -139,7 +139,7 @@ module Gitlab ...@@ -139,7 +139,7 @@ module Gitlab
# running job # running job
find_thread_with_lock(jid) do |thread| find_thread_with_lock(jid) do |thread|
Sidekiq.logger.warn( Sidekiq.logger.warn(
class: self.class, class: self.class.to_s,
action: 'cancel', action: 'cancel',
message: 'Canceling thread with CancelledError', message: 'Canceling thread with CancelledError',
jid: jid, jid: jid,
......
...@@ -25,5 +25,17 @@ describe Gitlab::SidekiqMiddleware::Monitor do ...@@ -25,5 +25,17 @@ describe Gitlab::SidekiqMiddleware::Monitor do
expect(result).to eq('value') expect(result).to eq('value')
end end
context 'when cancel happens' do
subject do
monitor.call(worker, job, queue) do
raise Gitlab::SidekiqMonitor::CancelledError
end
end
it 'does skip this job' do
expect { subject }.to raise_error(Sidekiq::JobRetry::Skip)
end
end
end end
end end
...@@ -54,7 +54,7 @@ describe Gitlab::SidekiqMonitor do ...@@ -54,7 +54,7 @@ describe Gitlab::SidekiqMonitor do
it 'logs start message' do it 'logs start message' do
expect(Sidekiq.logger).to receive(:info) expect(Sidekiq.logger).to receive(:info)
.with( .with(
class: described_class, class: described_class.to_s,
action: 'start', action: 'start',
message: 'Starting Monitor Daemon') message: 'Starting Monitor Daemon')
...@@ -66,7 +66,7 @@ describe Gitlab::SidekiqMonitor do ...@@ -66,7 +66,7 @@ describe Gitlab::SidekiqMonitor do
it 'logs stop message' do it 'logs stop message' do
expect(Sidekiq.logger).to receive(:warn) expect(Sidekiq.logger).to receive(:warn)
.with( .with(
class: described_class, class: described_class.to_s,
action: 'stop', action: 'stop',
message: 'Stopping Monitor Daemon') message: 'Stopping Monitor Daemon')
...@@ -78,7 +78,7 @@ describe Gitlab::SidekiqMonitor do ...@@ -78,7 +78,7 @@ describe Gitlab::SidekiqMonitor do
it 'logs StandardError message' do it 'logs StandardError message' do
expect(Sidekiq.logger).to receive(:warn) expect(Sidekiq.logger).to receive(:warn)
.with( .with(
class: described_class, class: described_class.to_s,
action: 'exception', action: 'exception',
message: 'My Exception') message: 'My Exception')
...@@ -91,7 +91,7 @@ describe Gitlab::SidekiqMonitor do ...@@ -91,7 +91,7 @@ describe Gitlab::SidekiqMonitor do
it 'logs and raises Exception message' do it 'logs and raises Exception message' do
expect(Sidekiq.logger).to receive(:warn) expect(Sidekiq.logger).to receive(:warn)
.with( .with(
class: described_class, class: described_class.to_s,
action: 'exception', action: 'exception',
message: 'My Exception') message: 'My Exception')
...@@ -131,13 +131,13 @@ describe Gitlab::SidekiqMonitor do ...@@ -131,13 +131,13 @@ describe Gitlab::SidekiqMonitor do
expect(Sidekiq.logger).to receive(:info) expect(Sidekiq.logger).to receive(:info)
.with( .with(
class: described_class, class: described_class.to_s,
action: 'start', action: 'start',
message: 'Starting Monitor Daemon') message: 'Starting Monitor Daemon')
expect(Sidekiq.logger).to receive(:info) expect(Sidekiq.logger).to receive(:info)
.with( .with(
class: described_class, class: described_class.to_s,
channel: described_class::NOTIFICATION_CHANNEL, channel: described_class::NOTIFICATION_CHANNEL,
message: 'Received payload on channel', message: 'Received payload on channel',
payload: payload payload: payload
...@@ -215,7 +215,7 @@ describe Gitlab::SidekiqMonitor do ...@@ -215,7 +215,7 @@ describe Gitlab::SidekiqMonitor do
it 'does log cancellation message' do it 'does log cancellation message' do
expect(Sidekiq.logger).to receive(:warn) expect(Sidekiq.logger).to receive(:warn)
.with( .with(
class: described_class, class: described_class.to_s,
action: 'cancel', action: 'cancel',
message: 'Canceling thread with CancelledError', message: 'Canceling thread with CancelledError',
jid: 'my-jid', jid: 'my-jid',
......
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