Celery在django环境下生成任务独立的log日志

Django框架中,使用celery可以实现异步任务的目的。对于web中费时的任务,可以加到celery中,防止阻塞界面,提高用户体验。

然而,使用celery的过程中,如果存在多种类型的任务时,所有任务的日志记录是个头疼的问题,如果直接使用python的logging模块,会出现日志文件为空,日志没有写入指定日志文件的情况。

celery提供了自己封装好的logging模块,如果设置正确,其效果还是挺好的。


# core/tasks.py
from celery import Task
from celery.utils.log import get_task_logger

def register_task_logger(module_name):
    """Instantiate a logger at the decorated class instance level."""
    def wrapper(cls):
        cls.log = get_task_logger('%s.%s' % (module_name, cls.__name__))
        return cls
    return wrapper

@register_task_log(__name__)
class AddTask(Task):

    def run(self, x, y):
        self.log.info("Calling task add(%d, %d)" % (x, y))
        return x - y

@register_task_log(__name__)
class SubTask(Task):

    def run(self, x, y):
        sel
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Django使用Celerydjango-celery-beat可以实现定时任务或周期性任务。下面是两种添加定时任务的方式: 1. 在celery.py中添加任务: 在你的项目中的celery.py文件中,你可以定义定时任务。首先,确保你已经安装了django-celery-beat,并将其添加到INSTALLED_APPS中。然后,在celery.py文件中添加以下代码: ```python from celery import Celery from django.conf import settings app = Celery('your_project_name') app.config_from_object('django.conf:settings', namespace='CELERY') app.autodiscover_tasks(lambda: settings.INSTALLED_APPS) @app.on_after_configure.connect def setup_periodic_tasks(sender, **kwargs): # 添加定时任务 sender.add_periodic_task(10.0, your_task.s(), name='your_task_name') @app.task def your_task(): # 定时任务的具体逻辑 pass ``` 在上面的代码中,`your_project_name`是你的项目名称,`your_task_name`是你给定时任务起的名字,`your_task`是你要执行的具体任务。 2. 通过Django admin后台添加任务django-celery-beat还提供了通过Django admin后台添加定时任务的方式。首先,在settings.py文件中添加`'django_celery_beat'`到INSTALLED_APPS中。然后,在终端运行以下命令创建数据库迁移: ```shell python manage.py makemigrations python manage.py migrate ``` 接下来,你可以通过访问Django admin后台来添加定时任务。在后台中,你可以设置任务的名称、任务的类型(定时任务或周期性任务)、任务的执行时间等。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值