| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 大数据 -> celery的简单测试,以及使用redis作为broker的时候,是用redis的哪种数据类型 -> 正文阅读 |
|
[大数据]celery的简单测试,以及使用redis作为broker的时候,是用redis的哪种数据类型 |
1、首先两个文件 <1> tasks (一般名称固定) tasks.py
<2>第二个文件是异步任务调度的入口? celery_test_main.py
2、启动异步 celery -A tasks worker --loglevel=info 3、运行celery_test_main.py文件添加任务 这里可以看到redis 2 号库是这样的 ?其实任务主要存在celery里面,这个key是个列表 ?列表里面有很多任务,里面的某一个元素是字符串的这种数据结构:
4、当任务都执行完毕之后,这个celery的列表就不存在了 5、而如果你把celery服务停止之后,运行celery_test_main.py文件,依然是能在redis的2号库添加任务;可以看到任务堆积了 而任务貌似是不会过期的: ?6、重启异步可以看到仍然可以正常执行未执行的任务 7、测试用3号库当作 backend 存储任务结果的库,里面结构是这样的 可以看到任务执行的成功与否的状态和执行完成的时间;以及是哪个任务(task_id) 8、可以再开一个终端再以同样的命令启动一个worker 可以看到启动两个更快,而且分别执行不同的任务(任务不会重复执行,取到哪个执行哪个worker从队列中取到哪个执行哪个) 9、如果任务执行失败看看是怎样的? <1>修改下代码,故意出错 修改之后依然能成功执行,我纳闷了,是不是该重启异步?重启异步试试 重启一个异步之后,只有重启的这个会失败,另外一个没有重启的异步还能成功: ? ?结果库: 有失败的,有成功的,看来修改完异步任务的话,要重启worker的,不然不生效啊 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/18 15:55:40- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |