mirror of
https://github.com/discourse/discourse.git
synced 2024-11-23 11:13:22 +08:00
PERF: instead of N redis operations perform in bulk
This commit is contained in:
parent
43345063b9
commit
1754fcccf7
|
@ -40,16 +40,18 @@ class RandomTopicSelector
|
|||
|
||||
results = []
|
||||
|
||||
left = count
|
||||
return results if count < 1
|
||||
|
||||
while left > 0
|
||||
id = $redis.lpop key
|
||||
break unless id
|
||||
|
||||
results << id.to_i
|
||||
left -= 1
|
||||
results = $redis.multi do
|
||||
$redis.lrange(key, 0, count-1)
|
||||
$redis.ltrim(key, count, -1)
|
||||
end
|
||||
|
||||
results = results[0]
|
||||
results.map!(&:to_i)
|
||||
|
||||
left = count - results.length
|
||||
|
||||
backfilled = false
|
||||
if left > 0
|
||||
ids = backfill(category)
|
||||
|
|
Loading…
Reference in New Issue
Block a user