DEV: Drop distributed mutex from`SidebarSiteSettingsBackfiller#backfill!` (#25674)

Why this change?

Backfilling can take a long time on a site with many users. As a
result, the `DistriburedMutex` will warn in the logs when the block takes
more than 60 seconds to complete. We can increase the lock validity but
the method is currently only called from a job which has a
`cluster_concurrency` set to `1`. Therefore, it is actually not
necessary for us to hold a `DistributedMutex` here.

What does this change do?

1. Removes the distributed mutex and adds a comment about the risk of
   calling the `SidebarSiteSettingsBackfiller#backfill!` method.a

2. Delete old sidebar category section links in batches for all users
   to avoid a single long running query.
This commit is contained in:
Alan Guo Xiang Tan 2024-02-15 06:21:03 +08:00 committed by GitHub
parent 52fb523bbb
commit a8b4d2e82c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 26 additions and 22 deletions

View File

@ -14,7 +14,7 @@ class SidebarSiteSettingsBackfiller
@linkable_klass, previous_ids, new_ids =
case setting_name
when "default_navigation_menu_categories"
[Category, previous_value.split("|"), new_value.split("|")]
[Category, previous_value.split("|").map(&:to_i), new_value.split("|").map(&:to_i)]
when "default_navigation_menu_tags"
klass = Tag
@ -31,30 +31,34 @@ class SidebarSiteSettingsBackfiller
@removed_ids = previous_ids - new_ids
end
# This should only be called from the `Jobs::BackfillSidebarSiteSettings` job as the job is ran with a cluster
# concurrency of 1 to ensure that only one process is running the backfill at any point in time.
def backfill!
DistributedMutex.synchronize("backfill_sidebar_site_settings_#{@setting_name}") do
SidebarSectionLink.where(
linkable_type: @linkable_klass.to_s,
linkable_id: @removed_ids,
).delete_all
User
.real
.where(staged: false)
.select(:id)
.find_in_batches do |users|
rows = []
user_ids = users.map(&:id)
users.each do |user|
user_ids.each do |user_id|
@added_ids.each do |linkable_id|
rows << {
user_id: user[:id],
user_id: user_id,
linkable_type: @linkable_klass.to_s,
linkable_id: linkable_id,
}
end
end
SidebarSectionLink.transaction do
SidebarSectionLink.where(
user_id: user_ids,
linkable_id: @removed_ids,
linkable_type: @linkable_klass.to_s,
).delete_all
SidebarSectionLink.insert_all(rows) if rows.present?
end
end