Browse Source

Add maintenance task for updating counter caches

closed-social-v3
Eugen Rochko 7 years ago
parent
commit
188cddefe9
1 changed files with 19 additions and 0 deletions
  1. +19
    -0
      lib/tasks/mastodon.rake

+ 19
- 0
lib/tasks/mastodon.rake View File

@ -62,4 +62,23 @@ namespace :mastodon do
end
end
end
namespace :maintenance do
desc 'Update counter caches'
task update_counter_caches: :environment do
Rails.logger.debug 'Updating counter caches for accounts...'
Account.unscoped.select('id').find_in_batches do |batch|
Account.where(id: batch.map(&:id)).update_all('statuses_count = (select count(*) from statuses where account_id = accounts.id), followers_count = (select count(*) from follows where target_account_id = accounts.id), following_count = (select count(*) from follows where account_id = accounts.id)')
end
Rails.logger.debug 'Updating counter caches for statuses...'
Status.unscoped.select('id').find_in_batches do |batch|
Status.where(id: batch.map(&:id)).update_all('favourites_count = (select count(*) from favourites where favourites.status_id = statuses.id), reblogs_count = (select count(*) from statuses as reblogs where reblogs.reblog_of_id = statuses.id)')
end
Rails.logger.debug 'Done!'
end
end
end

Loading…
Cancel
Save