Commit d7eb6972 authored by Stan Hu's avatar Stan Hu

Merge branch 'sh-geo-add-more-geo-event-debug-logs' into 'master'

Geo: Gracefully handle deleted events from Geo event log

See merge request gitlab-org/gitlab-ee!6506
parents 262d60f6 6bef73ae
---
title: 'Geo: Gracefully handle deleted events from Geo event log'
merge_request: 6506
author:
type: fixed
...@@ -45,13 +45,21 @@ module Gitlab ...@@ -45,13 +45,21 @@ module Gitlab
def handle_events(batch) def handle_events(batch)
batch.each do |event_log| batch.each do |event_log|
event = event_log.event
# If a project is deleted, the event log and its associated event data
# could be purged from the log. We ignore this and move along.
unless event
logger.warn("Unknown event", event_log_id: event_log.id)
next
end
unless can_replay?(event_log) unless can_replay?(event_log)
logger.event_info(event_log.created_at, 'Skipped event', event_data(event_log)) logger.event_info(event_log.created_at, 'Skipped event', event_data(event_log))
next next
end end
begin begin
event = event_log.event
event_klass_for(event).new(event, event_log.created_at, logger).process event_klass_for(event).new(event, event_log.created_at, logger).process
rescue NoMethodError => e rescue NoMethodError => e
logger.error(e.message) logger.error(e.message)
......
...@@ -25,6 +25,10 @@ module Gitlab ...@@ -25,6 +25,10 @@ module Gitlab
geo_logger.error(base_log_data(message, params)) geo_logger.error(base_log_data(message, params))
end end
def warn(message, params = {})
geo_logger.warn(base_log_data(message, params))
end
def debug(message, params = {}) def debug(message, params = {})
geo_logger.debug(base_log_data(message, params)) geo_logger.debug(base_log_data(message, params))
end end
......
...@@ -115,6 +115,20 @@ describe Gitlab::Geo::LogCursor::Daemon, :postgresql, :clean_gitlab_redis_shared ...@@ -115,6 +115,20 @@ describe Gitlab::Geo::LogCursor::Daemon, :postgresql, :clean_gitlab_redis_shared
daemon.run_once! daemon.run_once!
end end
it "logs a message if an associated event can't be found" do
new_event = create(:geo_event_log)
expect(Gitlab::Geo::Logger).to receive(:warn)
.with(hash_including(
class: 'Gitlab::Geo::LogCursor::Daemon',
message: 'Unknown event',
event_log_id: new_event.id))
daemon.run_once!
expect(::Geo::EventLogState.last_processed.id).to eq(new_event.id)
end
it 'logs a message for skipped events' do it 'logs a message for skipped events' do
secondary.update!(selective_sync_type: 'namespaces', namespaces: [group_2]) secondary.update!(selective_sync_type: 'namespaces', namespaces: [group_2])
......
...@@ -5,22 +5,26 @@ describe Gitlab::Geo::LogCursor::Logger do ...@@ -5,22 +5,26 @@ describe Gitlab::Geo::LogCursor::Logger do
subject(:logger) { described_class.new(LoggerSpec) } subject(:logger) { described_class.new(LoggerSpec) }
let(:data) { { pid: 111, class: 'LoggerSpec', message: 'Test' } }
before do before do
stub_const("#{described_class.name}::PID", 111) stub_const("#{described_class.name}::PID", 111)
end end
it 'logs an info event' do it 'logs an info event' do
expect(::Gitlab::Logger).to receive(:info).with(pid: 111, expect(::Gitlab::Logger).to receive(:info).with(data)
class: "LoggerSpec",
message: 'Test')
logger.info('Test') logger.info('Test')
end end
it 'logs a warning event' do
expect(::Gitlab::Logger).to receive(:warn).with(data)
logger.warn('Test')
end
it 'logs an error event' do it 'logs an error event' do
expect(::Gitlab::Logger).to receive(:error).with(pid: 111, expect(::Gitlab::Logger).to receive(:error).with(data)
class: "LoggerSpec",
message: 'Test')
logger.error('Test') logger.error('Test')
end end
......
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