From 668aab739f163645a7005212b3d57c6cc31b30ee Mon Sep 17 00:00:00 2001 From: Graeme Porteous Date: Tue, 14 Nov 2023 11:46:46 +0000 Subject: [PATCH 1/2] Update model invalidate cache callbacks Only run the callbacks when `no_xapian_reindex` hasn't been set. This will prevent excessive `NotifyCacheJob` jobs from being created overnight when `script/update_public_bodies_stats` or when user alert tracks email is sent. Fixes #8009 --- app/models/info_request_event.rb | 2 +- app/models/public_body.rb | 3 ++- app/models/user.rb | 8 ++++---- doc/CHANGES.md | 2 ++ 4 files changed, 9 insertions(+), 6 deletions(-) diff --git a/app/models/info_request_event.rb b/app/models/info_request_event.rb index 64a2cde8be..dee62fcde1 100644 --- a/app/models/info_request_event.rb +++ b/app/models/info_request_event.rb @@ -88,7 +88,7 @@ class InfoRequestEvent < ApplicationRecord self.event_type = "hide" end after_create :update_request, if: :response? - after_create :invalidate_cached_pages + after_update :invalidate_cached_pages, unless: :no_xapian_reindex after_commit -> { info_request.create_or_update_request_summary }, on: [:create] diff --git a/app/models/public_body.rb b/app/models/public_body.rb index 72a48a22e4..0b4ef2fa4c 100644 --- a/app/models/public_body.rb +++ b/app/models/public_body.rb @@ -116,7 +116,8 @@ def self.admin_title after_save :update_missing_email_tag - after_update :reindex_requested_from, :invalidate_cached_pages + after_update :reindex_requested_from, :invalidate_cached_pages, + unless: :no_xapian_reindex # Every public body except for the internal admin one is visible scope :visible, -> { where("public_bodies.id <> #{ PublicBody.internal_admin_body.id }") } diff --git a/app/models/user.rb b/app/models/user.rb index 526b893cb4..992bd25e83 100644 --- a/app/models/user.rb +++ b/app/models/user.rb @@ -181,9 +181,10 @@ class User < ApplicationRecord validate :email_and_name_are_valid after_initialize :set_defaults - after_update :reindex_referencing_models, - :update_pro_account, - :invalidate_cached_pages + + after_update :update_pro_account + after_update :reindex_referencing_models, :invalidate_cached_pages, + unless: :no_xapian_reindex acts_as_xapian texts: [:name, :about_me], values: [ @@ -330,7 +331,6 @@ def variety # requested_by: and commented_by: search queries also need updating after save def reindex_referencing_models - return if no_xapian_reindex == true return unless saved_change_to_attribute?(:url_name) expire_comments diff --git a/doc/CHANGES.md b/doc/CHANGES.md index af7cd4fba7..868e21e5c1 100644 --- a/doc/CHANGES.md +++ b/doc/CHANGES.md @@ -2,6 +2,8 @@ ## Highlighted Features +* Improve background job performance by limiting the number `NotifyCacheJob` + jobs created (Graeme Porteous) * Signpost key user administration contributions for requests on request list pages (Gareth Rees) * Signpost users to find new contact details for requests with delivery errors From a18b0454bd35fb36d633b4e016463564cd9e6284 Mon Sep 17 00:00:00 2001 From: Graeme Porteous Date: Tue, 14 Nov 2023 12:59:40 +0000 Subject: [PATCH 2/2] fixup! Update model invalidate cache callbacks --- app/models/info_request_event.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/models/info_request_event.rb b/app/models/info_request_event.rb index dee62fcde1..a1e2920fad 100644 --- a/app/models/info_request_event.rb +++ b/app/models/info_request_event.rb @@ -88,7 +88,7 @@ class InfoRequestEvent < ApplicationRecord self.event_type = "hide" end after_create :update_request, if: :response? - after_update :invalidate_cached_pages, unless: :no_xapian_reindex + after_create :invalidate_cached_pages, unless: :no_xapian_reindex after_commit -> { info_request.create_or_update_request_summary }, on: [:create]