14.flask+celery

安装

  • 模块

pip install celery
pip install eventlet
pip install -U "celery[redis]"
pip install redis

在Windows操作系统上,还需要安装另外一个东西,eventlet

image-20200905165531410

相关文档

celery文档

关系

img
  • task,任务

  • broker(中间人),存储任务的队列(借助redis实现)

  • worker:真正执行任务的工作者

  • backend:用来存储任务执行后的结果

配置

想要在flask中使用celery,可以配合redis数据库,redis配置如下:

其中redis数据库链接格式为:

若没有密码,则为:

多个redis链接

URL 的所有配置都可以自定义配置的,默认使用的是 localhost 的 6379 端口中 0 数据库。( Redis 默认有 16 个数据库)

可见性超时

可见性超时为将消息重新下发给另外一个程序之前等待确认的任务秒数。请注意查看下面的。

可以通过 broker_transport_options 选项进行修改:

默认的可见性超时时间为1个小时。

结果

如果想保存任务执行返回结果保存到Redis,需要进行以下配置:

简单测试

  • 用法

  1. 第一个参数为当前模块的名称

  2. 第二个参数为中间人(Broker)的链接 URL

  3. 第三个参数backend为存储结果的位置

  • 创建task.py

可以看见send_mail()中设置等待5000秒,通常这个函数会运行很久,毫无体验感,但是为了获取体验感使用celery进行加速。

运行 Celery 职程(Worker)服务

现在可以使用 worker 参数进行执行刚刚创建职程(Worker):

格式:

image-20200905171339504
image-20200905173728940

调用任务

需要调用我们创建的实例任务,可以通过 delay() 进行调用。

delay()apply_async() 的快捷方法,可以更好的控制任务的执行:

如果出现以下报错:

解决

其中mymodule为文件名称

ready() 可以检测是否已经处理完毕:

整个任务执行过程为异步的,如果一直等待任务完成,会将异步调用转换为同步调用:

image-20200905174318246

如果运行出现如下错误:

image-20200905173537139

如果任务出现异常,get() 会再次引发异常,可以通过 propagate 参数进行覆盖:

如果任务出现异常,可以通过以下命令进行回溯:

flask-celery

flask celery文档

最简示例

通过上面的步骤,下面即是在 Flask 中使用 Celery 的最简示例:

在后台调用:

运行 Celery 职程

通过动手得知如上.wait() 永远不会实际地返回。这是因为需要运行 Celery。可以这样把 Celery 以职程运行:

实例:

而在linux中,这样使用

这次结果就有了。

常见用途

  • 邮件发送,由于可能在发送邮件时,由于网络等其他原因,导致发送时间过长,从而时用户体验感低,因此配合celery使用,就能够让等待时间降低,从而提高用户体验感。

最后更新于

这有帮助吗?