如何在事件机器中实施无限循环



我需要在事件机器上有一个无限的环路,该环路不断读取redis队列。以下是我的代码。递归是正确的方法吗?我尝试了loop do循环,但无法以这种方式工作。

require 'em-hiredis'
def read
  d = @redis.blpop 'queue', 0
  d.callback do |_, value|
    p value
    read
  end.errback do |e|
    p e
    EM.next_tick { read }
  end
end
EM.run do
  @redis = EM::Hiredis.connect
  read
end

最好订阅redis pub/sub队列。https://gist.github.com/957367如果您确实需要一个循环,那么Em本身就是一个无限的循环,您只需要一遍又一遍地安排您的工作:

def read
  d = @redis.blpop 'queue', 0
  d.callback do |_, value|
    EM.next_tick { read }
  end.errback do |e|
    EM.next_tick { read }
  end
 end

最新更新