celery.exceptions.NotRegistered: 'tasks.add' + celery delay 坑 + python manage.py check 查看状态 -P eventlet Windows需要 enventlet支持

-1  windows系统需要eventlet 支持

pip install eventlet
参考:Python Celery 快速实现分布式的任务队列管理 (toutiao.com)

0.查看celery的worker状态 (worker==node)

(base) D:\djangotest\myrecrument>celery -A myrecrument  status
2021-01-23 00:12:53,091 job.views    68 INFO     i am in view
celery@DESKTOP-OTOBB8E: OK

1 node online.
参考:https://www.cnblogs.com/shanchuan/p/12818117.html

 

1.检查已经注册的task

 D:\djangotest\myrecrument\mycelery> celery -A tasks inspect registered

2. D:\djangotest\myrecrument>  python manage.py check   检查django项目语法

3.celery delay 坑

复制代码
def notify_interviewer(modeladmin,request,queryset):
    logger.info('i enter notify_interviewer...begin')
    candidates = ' '
    for obj in queryset:
        candidates = obj.username + ';' + candidates
    #dingtalk.send(candidates)
    
    send_dingtalk_message.delay(candidates)
    logger.info('i enter notify_interviewer...after delay')
复制代码

项目目录 __init__.py 忘了添加以下内容,造成task.delay卡主

from __future__ import absolute_import, unicode_literals

# This will make sure the app is always imported when
# Django starts so that shared_task will use this app.
from .celery import app as celery_app  #少了这一点,delay就卡住发送不了消息

__all__ = ('celery_app',)

 

posted @   littlevigra  阅读(1839)  评论(2编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
· 【译】Visual Studio 中新的强大生产力特性
· 2025年我用 Compose 写了一个 Todo App
点击右上角即可分享
微信分享提示