当前位置:  开发笔记 > 编程语言 > 正文

使用Redis延迟执行/安排?

如何解决《使用Redis延迟执行/安排?》经验,为你挑选了1个好方法。

任何根据Redis做延迟任务执行(即调度)的技巧?

也许是一些聪明的方法来延迟BLPOP给定的秒数?



1> efalcao..:

如果你想用redis进行调度,我建议使用有序集(z*)命令:

http://code.google.com/p/redis/wiki/SortedSets

你能做的是这样的:

ZADD jobs  

例如:

ZADD jobs 1291348355

然后,每隔一段时间(最多每秒)你就可以拉出应该运行的预定作业(或者应该已经运行):

ZRANGEBYSCORE jobs -inf, 

热潮,你得到了你的工作.当然,请确保从已排序的集中删除已完成的作业.


哦,老线程但是 - 亚历山大 - 你可以使用一种调度程序线程,它每N秒检查一次排序集合,只是将作业从排序集移动到主要作业列表,而主要工作工作者是blpop'ing.
推荐阅读
手机用户2402851335
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有