Python 中的 RQ 简介

发布于 2021-04-16 12:40:31 字数 1341 浏览 1885 评论 0

RQ(Redis Queue)是基于 Redis 的消息队列服务框架,任务进入队列后由后台进程处理之,它能轻易集成到系统中,仅支持 Python 语言。RQ 需要 Redis>=2.6.0 版本

安装

RQ 的安装方法非常简单,直接命令:

pip install rq

或者如果你想尝新的话,从 github 安装开发版:

pip install -e git+git@github.com:nvie/rq.git@master#egg=rq

开始

既然是基于 Redis 的服务,那么首先开启 Redis 是必须的,接着把任务放入队列中,任务就是你要处理某件事的过程,它是一个普通的Python函数,通常来说,把任务放在后台进程来处理的都是一些耗时的、对即时性要求比较低的任务,比如:用户注册网站时一般的流程是填写基本信息后会即时返回注册成功的结果,接着才是收到邮件通知要求验证邮件的有效性,其中这个发邮件的任务就可以交给RQ来做。

# my_module.py
def send_mail(email):
    # 模拟发送邮件的过程,整个邮件发送过程需要2秒钟
    time.sleep(2)
    return ‘ok’

然后创建一个 RQ 队列,把任务放入队列

>>> from my_module import send_mail
>>> from redis import Redis
>>> from rq import Queue
>>> q = Queue(connection=Redis())
>>> result = q.enqueue(send_mail, ‘hello@qq.com’)

最后一步就是启动后台进程,后台进程会完成该任务的处理。在项目的目录下执行:

$ rqworker

# 输出
02:25:06 RQ worker started, version 0.4.6
02:25:06
02:25:06 *** Listening on default...
02:25:06 default: my_module.send_mail(‘hello@qq.com’) (77778f9c-2947-4551-aa58-76a77c2c0d8e)
02:25:07 Job OK, result = ok
02:25:07 Result is kept for 500 seconds.

default 是创建队列的时候默认的名字,result=ok 是任务的返回结果。你看使用 RQ 就这么简单。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

文章
评论
84963 人气
更多

推荐作者

微信用户

文章 0 评论 0

小情绪

文章 0 评论 0

ゞ记忆︶ㄣ

文章 0 评论 0

笨死的猪

文章 0 评论 0

彭明超

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文