Commit 8207ee4f authored by Douglas Barbosa Alexandre's avatar Douglas Barbosa Alexandre

Merge branch 'mk/fix-project-wiki-events-for-selective-sync' into 'master'

Geo: Skip project/wiki repo create/update events based on selective sync

Closes #233504

See merge request gitlab-org/gitlab!39488
parents 82cddbc2 b9d7e7db
---
title: 'Geo: Skip project/wiki repo create/update events based on selective sync'
merge_request: 39488
author:
type: fixed
...@@ -37,6 +37,20 @@ module Gitlab ...@@ -37,6 +37,20 @@ module Gitlab
yield if healthy_shard_for?(event) yield if healthy_shard_for?(event)
end end
def replicable_project?
strong_memoize(:replicable_project) do
# If a registry exists, then it *should* be replicated. The
# registry will be removed by the delete event or
# RegistryConsistencyWorker if it should no longer be replicated.
#
# This early exit helps keep event processing efficient especially
# for repository updates which are a large proportion of events.
next true if registry.persisted?
Gitlab::Geo.current_node.projects_include?(event.project_id)
end
end
def log_event(message, params = {}) def log_event(message, params = {})
logger.event_info( logger.event_info(
created_at, created_at,
......
...@@ -8,6 +8,7 @@ module Gitlab ...@@ -8,6 +8,7 @@ module Gitlab
include BaseEvent include BaseEvent
def process def process
if replicable_project?
registry.repository_created!(event) registry.repository_created!(event)
job_id = nil job_id = nil
...@@ -15,6 +16,7 @@ module Gitlab ...@@ -15,6 +16,7 @@ module Gitlab
enqueue_job_if_shard_healthy(event) do enqueue_job_if_shard_healthy(event) do
job_id = ::Geo::ProjectSyncWorker.perform_async(event.project_id, sync_repository: true, sync_wiki: true) job_id = ::Geo::ProjectSyncWorker.perform_async(event.project_id, sync_repository: true, sync_wiki: true)
end end
end
log_event(job_id) log_event(job_id)
end end
...@@ -29,6 +31,7 @@ module Gitlab ...@@ -29,6 +31,7 @@ module Gitlab
wiki_path: event.wiki_path, wiki_path: event.wiki_path,
resync_repository: registry.resync_repository, resync_repository: registry.resync_repository,
resync_wiki: registry.resync_wiki, resync_wiki: registry.resync_wiki,
replicable_project: replicable_project?,
job_id: job_id) job_id: job_id)
end end
end end
......
...@@ -8,6 +8,7 @@ module Gitlab ...@@ -8,6 +8,7 @@ module Gitlab
include BaseEvent include BaseEvent
def process def process
if replicable_project?
registry.repository_updated!(event.source, scheduled_at) registry.repository_updated!(event.source, scheduled_at)
job_id = enqueue_job_if_shard_healthy(event) do job_id = enqueue_job_if_shard_healthy(event) do
...@@ -17,6 +18,7 @@ module Gitlab ...@@ -17,6 +18,7 @@ module Gitlab
sync_wiki: event.wiki? sync_wiki: event.wiki?
) )
end end
end
log_event(job_id) log_event(job_id)
end end
...@@ -31,6 +33,7 @@ module Gitlab ...@@ -31,6 +33,7 @@ module Gitlab
resync_repository: registry.resync_repository, resync_repository: registry.resync_repository,
resync_wiki: registry.resync_wiki, resync_wiki: registry.resync_wiki,
scheduled_at: scheduled_at, scheduled_at: scheduled_at,
replicable_project: replicable_project?,
job_id: job_id) job_id: job_id)
end end
......
...@@ -3,6 +3,9 @@ ...@@ -3,6 +3,9 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe Gitlab::Geo::LogCursor::Events::RepositoryCreatedEvent, :clean_gitlab_redis_shared_state do RSpec.describe Gitlab::Geo::LogCursor::Events::RepositoryCreatedEvent, :clean_gitlab_redis_shared_state do
include ::EE::GeoHelpers
let_it_be(:secondary) { create(:geo_node) }
let(:logger) { Gitlab::Geo::LogCursor::Logger.new(described_class, Logger::INFO) } let(:logger) { Gitlab::Geo::LogCursor::Logger.new(described_class, Logger::INFO) }
let(:project) { create(:project) } let(:project) { create(:project) }
let(:repository_created_event) { create(:geo_repository_created_event, project: project) } let(:repository_created_event) { create(:geo_repository_created_event, project: project) }
...@@ -15,6 +18,10 @@ RSpec.describe Gitlab::Geo::LogCursor::Events::RepositoryCreatedEvent, :clean_gi ...@@ -15,6 +18,10 @@ RSpec.describe Gitlab::Geo::LogCursor::Events::RepositoryCreatedEvent, :clean_gi
Sidekiq::Testing.fake! { example.run } Sidekiq::Testing.fake! { example.run }
end end
before do
stub_current_geo_node(secondary)
end
RSpec.shared_examples 'RepositoryCreatedEvent' do RSpec.shared_examples 'RepositoryCreatedEvent' do
it 'creates a new project registry' do it 'creates a new project registry' do
expect { subject.process }.to change(Geo::ProjectRegistry, :count).by(1) expect { subject.process }.to change(Geo::ProjectRegistry, :count).by(1)
...@@ -35,6 +42,18 @@ RSpec.describe Gitlab::Geo::LogCursor::Events::RepositoryCreatedEvent, :clean_gi ...@@ -35,6 +42,18 @@ RSpec.describe Gitlab::Geo::LogCursor::Events::RepositoryCreatedEvent, :clean_gi
registry = Geo::ProjectRegistry.last registry = Geo::ProjectRegistry.last
expect(registry).to have_attributes(project_id: project.id, resync_repository: true, resync_wiki: false) expect(registry).to have_attributes(project_id: project.id, resync_repository: true, resync_wiki: false)
end end
context 'when outside selective sync' do
before do
selective_sync_secondary = create(:geo_node, selective_sync_type: 'shards', selective_sync_shards: ['non-existent'])
stub_current_geo_node(selective_sync_secondary)
end
it 'does not create a new project registry' do
expect { subject.process }.not_to change(Geo::ProjectRegistry, :count)
end
end
end end
describe '#process' do describe '#process' do
......
...@@ -28,6 +28,18 @@ RSpec.describe Gitlab::Geo::LogCursor::Events::RepositoryUpdatedEvent, :clean_gi ...@@ -28,6 +28,18 @@ RSpec.describe Gitlab::Geo::LogCursor::Events::RepositoryUpdatedEvent, :clean_gi
expect { subject.process }.to change(Geo::ProjectRegistry, :count).by(1) expect { subject.process }.to change(Geo::ProjectRegistry, :count).by(1)
end end
context 'when outside selective sync' do
before do
selective_sync_secondary = create(:geo_node, selective_sync_type: 'shards', selective_sync_shards: ['non-existent'])
stub_current_geo_node(selective_sync_secondary)
end
it 'does not create a new project registry' do
expect { subject.process }.not_to change(Geo::ProjectRegistry, :count)
end
end
context 'when we have an event source' do context 'when we have an event source' do
before do before do
repository_updated_event.update!(source: event_source) repository_updated_event.update!(source: event_source)
......
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