使用LPUSH和BRPOPLPUSH (http://redis.io/commands/rpoplpush)在Redis中实现持久队列是一种众所周知的模式。然而,为了扩大规模,设计需要满足来自主要任务队列的多个工作人员/消费者,即BRPOPLPUSH。
因此,标准似乎是,对于每个工作人员,都有一个单独的processing_queue来记录特定工作人员正在执行的任务,这样,该工作人员就可以跟踪在处理过程中它退出时还需要做什么。
关于这个processing_queue,我有两个问题
processing_queue之前先检查它自己的BRPOPLPUSH中的任何剩余任务。如果是这样的话,我们可以使用任意一个RPOP、LPOP、LREM来删除工作人员完成处理后的任务(或者它可以简单地删除列表)。我们甚至可以使用一个集合而不是一个列表。为什么这么多人选择使用LREM,而没有其他原因呢?processing_queue。但是,当旧工作人员退出时,一个新的进程ID (很可能是新的)生成时会发生什么情况呢?新工作人员如何查找其前任的processing_queue来完成可能的遗留任务?我计划使用Supervisor来管理我的工作进程,如果这有区别的话。发布于 2015-06-15 22:30:52
processing_queue中。Supervisor,但您可以保留一个单独的数据结构--在这里最好使用排序集--员工的标识符作为元素,时间戳作为他们的分数。让员工定期更新他们的时间戳,并且当您启动一个新员工时,让它检查那些已经空闲太久的员工的设置。当发现这种情况时,试着确定它实际上已经死亡,然后让新工人接管相关的processing_queue (即in )。使用RENAME)。https://stackoverflow.com/questions/30855571
复制相似问题