Django Celery 如何配置task的日志输出到文件

在将celery和django整合起来进行使用的时候,之前调试看日志都是直接在tasks.py中写print(...)进行debug和查看具体运行日志。

经过多番查阅,最终实现了如何去自定义celery相关日志配置,可将日志输出到文件,并与django整合起来。

1. Celery 日志的默认配置

其实,Celery会把print语句重定向到自己的给自己的日志处理,celery是有一套自己处理日志的模块的,所以调试才会在控制台看到print的语句。

此时为了使用自己的配置,需要禁用默认配置

# disable dafault config
worker_hijack_root_logger = False

关于该参数,可见 https://docs.celeryproject.org/en/stable/userguide/configuration.html 搜索配置项名称即可见相关解释

2. Django 日志配置

setting.py中配置LOGGING,增加celery相关配置,建议如下


LOGGING_DIR = os.path.join(BASE_DIR, 'logs')
if not os.path.exists(LOGGING_DIR):
    os.makedirs(LOGGING_DIR)

LOGGING = {
    ......
    'handlers': {
        ......
        'console': {
            'level': 'DEBUG',
            'class': 'logging.StreamHandler',
        },
        'celery': {
            'level': 'INFO',
            # 此处可能需要注意celery多进程的写日志
            'class': 'logging.handlers.RotatingFileHandler',
            'filename': os.path.join(LOGGING_DIR, 'celery.log'),
            'maxBytes': 1024 * 1024 * 10,
            'backupCount': 3,
        },
    },
    'loggers': {
        ......
        'celery': {
            'handlers': ['console', 'celery'],
            'propagate': True,
            'level': 'DEBUG',
        },
    },
}

3. tasks.py 如何引入日志

通过以上配置,则可以简单地在task中使用自定义的配置

import logging

logger = logging.getLogger('celery')

@celery_app.task
def add_task():
    logger.info("start to calculate ...")
    ......

4. 日志查看

最终会发现

  • 在控制台看到DEBUG及以上的日志内容,且格式是自己定义的
  • celery.log日志文件中可以看到INFO及以上的日志
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值