www.adminn.cn
站长正能量分享网!

【Lavavel】RedisQueue如何执行队列任务?

AD:阿里云服务器企业会员更优惠 腾讯云香港,韩国免备案服务器1.8折优惠

利用Redis可以很方便的实现一个任务队列,本篇文章是对队列的执行原理的简单介绍。

队列的基本功能:

1、立即执行;yes

2、延迟执行;yes

3、保证至少执行一次;yes

4、必须执行且最多执行一次;no

用到的数据结构:

list、Sorted sets

延迟执行的机制:

1、先把数据放入SortedSets类型的queues:queue_000:delayed中

2、在执行pop的时候,执行lua脚本,把SortedSets类型的queues:queue_000:delayed 中可以执行的数据rpush到list类型的queues:queue_000中

保证执行成功的机制:

1、把要执行的数据先放入SortedSets类型的queues:queue_000:reserved中

2、在执行pop的时候,执行lua脚本,把SortedSets类型的queues:queue_000:reserved 中可以执行的数据rpush到list类型的queues:queue_000中

3、任务执行成功,从SortedSets类型的queues:queue_000:reserved中执行删除预存的数据

模板优惠价: (点击购买)
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《【Lavavel】RedisQueue如何执行队列任务?》
文章链接:https://www.adminn.cn/news/7779.html
本站资源模板仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。2021.5月起,网站调整,暂不再分享免费模板。谢谢理解

扫码支付后请联系右侧QQ发送下载地址!!

源码请勿用于任何涉灰站点!净化网络,站长更有责!

支付宝扫一扫打赏