discourse/app/jobs/scheduled/ensure_db_consistency.rb
Kelv 04ba5baec0
DEV: ensure rebaking works even when some users have inconsistent data (#30261)
* DEV: add db consistency check for UserEmail

* DEV: add db consistency check for UserAvatar

* DEV: ignore inconsistent data related to user avatars when deciding whether to rebake old posts


Co-authored-by: Alan Guo Xiang Tan <gxtan1990@gmail.com>

---------

Co-authored-by: Alan Guo Xiang Tan <gxtan1990@gmail.com>
2024-12-16 19:48:25 +08:00

66 lines
1.4 KiB
Ruby

# frozen_string_literal: true
module Jobs
# various consistency checks
class EnsureDbConsistency < ::Jobs::Scheduled
every 12.hours
def execute(args)
start_measure
[
UserVisit,
Group,
Notification,
TopicFeaturedUsers,
PostRevision,
Topic,
Badge,
CategoryUser,
UserOption,
Tag,
CategoryTagStat,
User,
UserAvatar,
UserEmail,
Category,
TopicThumbnail,
].each do |klass|
klass.ensure_consistency!
measure(klass)
end
UserAction.ensure_consistency!(13.hours.ago)
measure(UserAction)
UserStat.ensure_consistency!(13.hours.ago)
measure(UserStat)
GroupUser.ensure_consistency!(13.hours.ago)
measure(GroupUser)
Rails.logger.debug(format_measure)
nil
end
private
def format_measure
result = +"EnsureDbConsistency Times\n"
result << @measure_times.map { |name, duration| " #{name}: #{duration}" }.join("\n")
result
end
def start_measure
@measure_times = []
@measure_start = Process.clock_gettime(Process::CLOCK_MONOTONIC)
end
def measure(step = nil)
@measure_now = Process.clock_gettime(Process::CLOCK_MONOTONIC)
@measure_times << [step, @measure_now - @measure_start] if @measure_start
@measure_start = @measure_now
end
end
end