Use multiple pairs for zadd in PrecomputeFeedService (#3990)

This commit is contained in:
Akihiko Odaki (@fn_aki@pawoo.net) 2017-06-29 08:25:31 +09:00 committed by Eugen Rochko
parent 60b2b56d38
commit f79c10162e

View file

@ -13,21 +13,16 @@ class PrecomputeFeedService < BaseService
attr_reader :account attr_reader :account
def populate_feed def populate_feed
redis.pipelined do pairs = statuses.reverse_each.map(&method(:process_status))
statuses.reverse_each do |status|
process_status(status)
end
redis.pipelined do
redis.zadd(account_home_key, pairs)
redis.del("account:#{@account.id}:regeneration") redis.del("account:#{@account.id}:regeneration")
end end
end end
def process_status(status) def process_status(status)
add_status_to_feed(status) unless status_filtered?(status) [status.id, status.reblog? ? status.reblog_of_id : status.id] unless status_filtered?(status)
end
def add_status_to_feed(status)
redis.zadd(account_home_key, status.id, status.reblog? ? status.reblog_of_id : status.id)
end end
def status_filtered?(status) def status_filtered?(status)