Celery入门指北

其实本文就是我看完Celery的官方文档指南的读书笔记。然后由于我的懒,只看完了那些入门指南,原文地址:First Steps with CeleryNext StepsUsing Celery with Django。ps:本文基于celery版本4.0.2

First Steps with Celery

其实先要理解Celery是干什么的,在我的个人理解里,他是用来管理消息队列的,具体一点讲就是,有一百个任务要分给十个人做,Celery就是负责分这一部分的工作。

在这个入门指南里,官方文档给出了存放这这一百个任务的最佳储存方式,就是RabbitMQ,其次的话就是Redis

安装的话就直接用万能的pip就可以了。

在具体声明任务,调用任务这一块,文档给了非常简单的例子,个人感觉还要找其他稍微复杂一点的例子才能更好地理解是怎么用的。

而关于保存任务运行结果,也是可以放在RebbitMQ里或者其他数据库里。

至于配置文件,在刚入门这个情况下,只用默认就够了。

Next Steps

这一章也只是简单地介绍一些celery的特性,想要更详细的必须要看使用指南。

比如如何在我们的应用里用Celery,在我们应用的根目录下,创建celery.pytasks.py,前者负责生成和配置一个celery的实例,后者则是负责声明任务,任务的形式与声明普通函数类似,就是要在这些函数上面加上一个特定的装饰器。

那么如何调用这个 celery这个实例呢,文档给出的示例是用命令行启动。而调用任务的话,就是用任务的delay()方法。

在调用任务这部分,celery提供了一些有用的API,比如延时功能,偏函数赋值功能(就是先给一部分参数,后面再给另外一部分参数)。

celery还内置了一些基础的任务基元(不懂翻译这个),就是辅助我们构造出复杂的工作流程的工具。

任务路由方面,可以在配置文件中定制,在可以在命令行运行的时候以参数形式传入。

远程控制这部分暂时跳过。

时区设置,可以在配置文件中设置。

优化方面,默认配置是针对普通情况的,想要进一步优化就要看优化文档。不过如果有使用RabbitMQ的话,可以用librabbitmq这个库。

Using Celery with Django

Django和Celery是有特殊的合作方式的。

  • 先在project的文件夹下创建celery.py文件,如前文所讲,这个文件的任务就是配置并实例化celery。
  • 然后也是在这个文件夹下,更改__init__.py,目的是为了启动项目时候,会导入celery.py
  • 然后就是在app的文件夹下创建tasks.py来声明任务,值得注意的就是,这些任务需要用到@shared_task这个装饰器。

具体的话可以看官方的例子

Celery入门指北的更多相关文章

  1. Python 简单入门指北(二)

    Python 简单入门指北(二) 2 函数 2.1 函数是一等公民 一等公民指的是 Python 的函数能够动态创建,能赋值给别的变量,能作为参传给函数,也能作为函数的返回值.总而言之,函数和普通变量 ...

  2. Python 简单入门指北(一)

    Python 简单入门指北(一) Python 是一门非常容易上手的语言,通过查阅资料和教程,也许一晚上就能写出一个简单的爬虫.但 Python 也是一门很难精通的语言,因为简洁的语法背后隐藏了许多黑 ...

  3. 关于supervisor的入门指北

    关于supervisor的入门指北 在目前这个时间点(2017/07/25),supervisor还是仅支持python2,所以我们要用版本管理pyenv来隔离环境. pyenv 根据官方文档的讲解, ...

  4. Angular 从入坑到挖坑 - Router 路由使用入门指北

    一.Overview Angular 入坑记录的笔记第五篇,因为一直在加班的缘故拖了有一个多月,主要是介绍在 Angular 中如何配置路由,完成重定向以及参数传递.至于路由守卫.路由懒加载等&quo ...

  5. Electron入门指北

    最近几年最火的桌面化技术,无疑是Qt+和Electron. 两者都有跨平台桌面化技术,并不局限于Windows系统.前者因嵌入式而诞生,在演变过程中,逐步完善了生态以及工具链.后者则是依托于Node. ...

  6. SourceGenerator入门指北

    SourceGenerator介绍 SourceGenerator于2020年4月29日在微软的.net blog首次介绍,大概说的是开发者编可以写分析器,在项目代码编译时,分析器分析项目既有的静态代 ...

  7. 后端API入门到放弃指北

    后端API入门学习指北 了解一下一下概念. RESTful API标准] 所有的API都遵循[RESTful API标准]. 建议大家都简单了解一下HTTP协议和RESTful API相关资料. 阮一 ...

  8. 关于Gevent的使用指北

    关于Gevent的使用指北 只是看了入门指南,和一个翻译文档.写一下个人读书心得. 其实看完之后,第一个反映就是asyncio这个系统库,感觉gevent现在所做的一些事情是与asyncio很像的,但 ...

  9. 颓废选手在 Ubuntu/Noilinux 下的生存指北

    颓废选手在 Ubuntu/Noilinux 下的生存指北 Hint: 这里的 "#" 都是假注释,复制的时候记得删除 一些基本的生存命令 ctrl + alt + t #调出终端 ...

随机推荐

  1. windows下设置计划任务自动执行PHP脚本

    背景: 环境部署在linux下或者windows中,可以使用windows的自动任务设置自动执行脚本执行一些日常运维任务 图形界面设置相对比较简单 准备工作: wamp(集成的PHP执行环境) 已经写 ...

  2. ADC自动转接功能Lua实现

    一.背景介绍: 虽然使用Mod_fifo和mod_callcenter可以做呼叫中心的应用,但在实现应用中,这两个模块很难客制化需求,再此我用Lua实现了5路客服(1000-1004),一个呼叫中心号 ...

  3. Springboot分模块开发详解(1):建立父工程

    基础服务,见下: base是父工程,base-entity是实体层,base-dao是DAO层,base-service是业务层,base-controller是WEB控制器层,base-web是页面 ...

  4. Expm 7_1树中的最大独立集问题

    [问题描述] 给定一个无回路的无向图(即树),设计一个动态规划算法,求出该图的最大独立集,并输出该集合中的各个顶点值. package org.xiu68.exp.exp7; import java. ...

  5. bzoj 1060

    这题其实有点骗人... 通过观察很容易发现:考虑某一些叶节点的LCA,由于根节点到这个LCA的距离唯一,故要求这些叶节点到这一LCA的距离都相等 于是我们仅需dfs,找到次底层的节点,然后使这些节点的 ...

  6. 性能测试三十五:jvm垃圾回收-GC

    垃圾回收-GC 三个问题 哪些内存需要回收? 什么时候回收? 如何回收? YoungGC和FullGC: 新生代引发的GC叫YoungGC 老年代引发的GC叫FullGC FullGC会引起整个Jvm ...

  7. 性能测试二十二:环境部署之Nginx

    由于单纯用tomcat只能通过ip+端口号的形式访问,这样只能访问一个tomcat,而真实项目中又不可能只用一两个tomcat,所以就需要Nginx来进行分配访问请求, Nginx本身性能非常好,据官 ...

  8. python3 + selenium 之窗口切换

    窗口切换 此代码来源学习后对淘宝操作实践记录: 以下代码在Chrome61和IE11上正常运行,Firefox5.7上运行存在一些问题须改进,应该是火狐不兼容差link_text部分和循环经常报错,在 ...

  9. ERP退货系统管理(四十五)

    添加的存储过程:(添加退货申请信息的存储过程) CREATE PROCEDURE [dbo].[BioBackSendGoods_ADD] @SendBackID INT OUTPUT, ), @Ap ...

  10. 【C++ Primer 第10章】 10.4.2 插入迭代器

    iostream迭代器 标准库为iostream定义了可用于这些IO类型对象的迭代器. istream_iterator读取输入流, ostream_iterator向一个输出流写数据.   1. i ...