Add proper queuing for feed events
This commit is contained in:
parent
de77c71042
commit
3ac766530d
1 changed files with 14 additions and 4 deletions
|
@ -45,13 +45,14 @@ end
|
|||
def refresh_feeds(db, logger, max_threads = 1, use_feed_events = false)
|
||||
max_channel = Channel(Int32).new
|
||||
|
||||
# TODO: Instead of Fiber.yield, use proper queuing to prevent overloading DB
|
||||
# Spawn thread to handle feed events
|
||||
if use_feed_events
|
||||
queue = Deque(String).new(30)
|
||||
|
||||
spawn do
|
||||
PG.connect_listen(PG_URL, "feeds") do |event|
|
||||
spawn do
|
||||
feed = JSON.parse(event.payload)
|
||||
loop do
|
||||
if event = queue.shift?
|
||||
feed = JSON.parse(event)
|
||||
email = feed["email"].as_s
|
||||
action = feed["action"].as_s
|
||||
|
||||
|
@ -61,11 +62,20 @@ def refresh_feeds(db, logger, max_threads = 1, use_feed_events = false)
|
|||
when "refresh"
|
||||
db.exec("REFRESH MATERIALIZED VIEW #{view_name}")
|
||||
end
|
||||
|
||||
# Delete any future events that we just processed
|
||||
queue.delete(event)
|
||||
else
|
||||
sleep 1.second
|
||||
end
|
||||
|
||||
Fiber.yield
|
||||
end
|
||||
end
|
||||
|
||||
PG.connect_listen(PG_URL, "feeds") do |event|
|
||||
queue << event.payload
|
||||
end
|
||||
end
|
||||
|
||||
spawn do
|
||||
|
|
Loading…
Reference in a new issue