本文使用REDIS列表进行排队和pub/sub。尽管列表使用LPUSH/RPOP有效地实现了FIFO/LIFO队列,但与Redis的本机机制相比,它们对酒吧/sub的效率低下。本文还讨论了性能
REDIS列表提供了一种直接实现排队和发布/订阅(PUB/SUB)系统的简单方法,尽管它们更适合排队。让我们分解每个用例:
排队: REDIS列表使用LPUSH
(左推)和RPOP
(右POP)命令来实现首先出局(FIFO)队列。 LPUSH
将元素添加到列表的头部,而RPOP
删除并返回尾部的元素。这会创建一个经典的队列,其中按添加的顺序处理项目。对于最后一in的首次输出(LIFO)堆栈,您将使用RPUSH
(右推)和LPOP
(左POP)。
示例(FIFO队列):
想象一个任务队列。工人从名为“任务”的列表中消费任务:
LPUSH tasks "task1"
将任务添加到队列中。BRPOP tasks 0
(阻止POP)等待任务。 BRPOP
块,直到可以使用任务或达到超时(0表示无限等待)。一旦可用任务,就将其删除并处理。 Pub/sub:虽然REDIS列表可以适用于Pub/Sub,但这不是其主要优势。 Redis使用PUBLISH
和SUBSCRIBE
命令的内置酒吧/子机制更有效,专门为此目的而设计。使用酒吧/sub的列表将涉及将消息推向列表,并让订阅者反复对新消息的列表进行轮询,这是效率低下的,与本机酒吧/sub相比,订阅效率低下。因此,对于Pub/sub,使用Redis的本机酒吧/子功能。
Redis提供了几种适合排队的数据结构,每个数据结构都具有性能权衡:
BRPOP
可以在繁重的争论中成为瓶颈,许多消费者等待任务。内存使用情况与队列大小线性缩放。总而言之:列表适用于简单的低频率队列。对于高通量,可靠和可扩展的队列,Redis流是首选的选择。当任务优先级至关重要时,排序集是理想的。
仅使用REDIS列表实施真正可靠的消息队列是具有挑战性的。 REDIS列表本身没有提供服务器内存以外的消息持久性之类的功能。为了提高可靠性,请考虑以下策略:
LPUSH
和RPOP
操作在交易( MULTI
, EXEC
)中以确保原子性。在发生故障的情况下,这可以防止部分操作。这些技术可提高可靠性,但在极端情况下不会消除数据丢失的可能性。对于关键任务应用程序,建议使用更强大的消息队列系统(例如,Kafka,RabbitMQ)。
如前所述,REDIS列表不是酒吧/子的理想选择。但是,如果您必须使用它们,请遵循这些做法(请记住,这些方法是解决方法,效率较低,效率较低):
LRANGE
持续少量超时对列表进行轮询,这是高效效率的。它浪费了资源并增加了延迟。BLPOP
或BRPOP
:阻止POP(左POP的BLPOP
,右POP的BRPOP
)比投票更有效。他们只有在有消息可用时消耗资源。至关重要的是,请记住,Redis的天然酒吧/子系统对于酒吧/子方案而言要出色。这些“最佳实践”仅仅是用于使用不为任务设计的工具的缓解策略。使用REDIS列表进行排队,并使用Redis的内置酒吧/子进行发布/订阅操作,以实现最佳性能和可伸缩性。
以上是如何使用REDIS列表进行排队和酒吧/sub?的详细内容。更多信息请关注PHP中文网其他相关文章!