Celery入门指北
Celery入门指北
其实本文就是我看完Celery的官方文档指南的读书笔记。然后由于我的懒,只看完了那些入门指南,原文地址:First Steps with Celery,Next Steps,Using Celery with Django。ps:本文基于celery版本4.0.2
First Steps with Celery
其实先要理解Celery是干什么的,在我的个人理解里,他是用来管理消息队列的,具体一点讲就是,有一百个任务要分给十个人做,Celery就是负责分这一部分的工作。
在这个入门指南里,官方文档给出了存放这这一百个任务的最佳储存方式,就是RabbitMQ,其次的话就是Redis。
安装的话就直接用万能的pip就可以了。
在具体声明任务,调用任务这一块,文档给了非常简单的例子,个人感觉还要找其他稍微复杂一点的例子才能更好地理解是怎么用的。
而关于保存任务运行结果,也是可以放在RebbitMQ里或者其他数据库里。
至于配置文件,在刚入门这个情况下,只用默认就够了。
Next Steps
这一章也只是简单地介绍一些celery的特性,想要更详细的必须要看使用指南。
比如如何在我们的应用里用Celery,在我们应用的根目录下,创建celery.py和tasks.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入门指北的更多相关文章
- Python 简单入门指北(二)
Python 简单入门指北(二) 2 函数 2.1 函数是一等公民 一等公民指的是 Python 的函数能够动态创建,能赋值给别的变量,能作为参传给函数,也能作为函数的返回值.总而言之,函数和普通变量 ...
- Python 简单入门指北(一)
Python 简单入门指北(一) Python 是一门非常容易上手的语言,通过查阅资料和教程,也许一晚上就能写出一个简单的爬虫.但 Python 也是一门很难精通的语言,因为简洁的语法背后隐藏了许多黑 ...
- 关于supervisor的入门指北
关于supervisor的入门指北 在目前这个时间点(2017/07/25),supervisor还是仅支持python2,所以我们要用版本管理pyenv来隔离环境. pyenv 根据官方文档的讲解, ...
- Angular 从入坑到挖坑 - Router 路由使用入门指北
一.Overview Angular 入坑记录的笔记第五篇,因为一直在加班的缘故拖了有一个多月,主要是介绍在 Angular 中如何配置路由,完成重定向以及参数传递.至于路由守卫.路由懒加载等&quo ...
- Electron入门指北
最近几年最火的桌面化技术,无疑是Qt+和Electron. 两者都有跨平台桌面化技术,并不局限于Windows系统.前者因嵌入式而诞生,在演变过程中,逐步完善了生态以及工具链.后者则是依托于Node. ...
- SourceGenerator入门指北
SourceGenerator介绍 SourceGenerator于2020年4月29日在微软的.net blog首次介绍,大概说的是开发者编可以写分析器,在项目代码编译时,分析器分析项目既有的静态代 ...
- 后端API入门到放弃指北
后端API入门学习指北 了解一下一下概念. RESTful API标准] 所有的API都遵循[RESTful API标准]. 建议大家都简单了解一下HTTP协议和RESTful API相关资料. 阮一 ...
- 关于Gevent的使用指北
关于Gevent的使用指北 只是看了入门指南,和一个翻译文档.写一下个人读书心得. 其实看完之后,第一个反映就是asyncio这个系统库,感觉gevent现在所做的一些事情是与asyncio很像的,但 ...
- 颓废选手在 Ubuntu/Noilinux 下的生存指北
颓废选手在 Ubuntu/Noilinux 下的生存指北 Hint: 这里的 "#" 都是假注释,复制的时候记得删除 一些基本的生存命令 ctrl + alt + t #调出终端 ...
随机推荐
- WCF错误远程服务器返回了意外响应: (413) Request Entity Too Large。解决方案
这个问题出现的原因是 调用wcf服务的时候传递的参数 长度太大 wcf数据传输采用的默认的大小是65535字节. ---------------------------------------- ...
- 命令查看WebSphere MQ运行状态
参考:https://wenku.baidu.com/view/34e40e2ffd0a79563c1e72b9.html 一.查看队列管理器运行状态 # dspmq 显示结果中QMNAME表示MQ队 ...
- Tomcat启动项目时内存溢出问题如何解决
在Eclipse中,内存溢出(报不能创建JAVA虚拟机错时,也可能是这里配错了.) 1.双击Tomcat,点击Open launch configuration,Arguments, 2.在VM ar ...
- mysql数据库报错:InnoDB: Operating system error number 13 in a file operation
环境:centos6.5 x86_64 启动mysql发现日志报错(日志路径可以查看/etc/my.cnf的配置) 160722 10:34:08 [Note] Found 42570716 of 4 ...
- openvpn用户管理、linux客户端配置及企业常用真实案例解析
1.给企业用户分配VPN账户的流程: 添加拨号需要密码的用户 # source vars NOTE: If you run ./clean-all, I will be doing a rm -rf ...
- 百度地图的Icon
在百度地图的类说明中,查看对Icon的构建: 定制IconOptions 看下面的差别 发现在IconOptions没有imageSize属性 而在实际测试中,代码如下 <script type ...
- 内存分配方式,堆区,栈区,new/delete/malloc/free
1.内存分配方式 内存分配方式有三种: [1]从静态存储区域分配.内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在.例如全局变量,static变量. [2]在栈上创建.在执行函数时 ...
- main.js 里的/* eslint-disable no-new */
注意项目中的这个,它的作用是: 在js里面,new 一个对象,需要赋值给某个值(变量),用Vue实例化的时候,不需要赋值给值(变量),所以要单独给配一条规则,给new Vue这行代码上面加这个注释,把 ...
- SQL代码整理
--SQL代码整理: create database mingzi--创建数据库go--连接符(可省略)create table biao--创建表( lieming1 int not null,-- ...
- react之自定义react-redux的provider、connect
Provider // Provider把store放到context里,所有的子元素可以直接取到store import React from 'react' import PropTypes fr ...