gpt4 book ai didi

python - 我可以在不启动并行进程的情况下在 Django 中运行后台进程吗?

转载 作者:行者123 更新时间:2023-11-28 21:41:59 33 4
gpt4 key购买 nike

这是一个非常幼稚的问题,但我觉得我不了解有关 django 和 python 中的异步/后台任务的一些基本知识。

我尝试复制 django-background-tasks ( https://github.com/collinmutembei/django-background-tasks-example ) 提供的一个简单示例,以使 django 比实际运行晚 60 秒执行后台任务。但我想这同样适用于任何其他后台任务管理器,例如 Celery 或 Huey

这个例子非常简单 - 一旦用户访问 url,一个简单的打印消息的函数就会在 60 秒后执行,而不会阻塞主 django 进程

  from background_task import background
from logging import getLogger

logger = getLogger(__name__)

@background(schedule=60)
def demo_task(message):
logger.debug('demo_task. message={0}'.format(message))

问题是我真的不了解基础知识。它不会运行,除非我启动一个单独的(或分离的)进程 python manage.py process_tasks。我应该始终执行此操作以使后台任务正常工作,还是有一种方法可以在不启动并行进程的情况下执行此操作?

如果我应该启动一个并行进程,我可以从 Django 代码内部进行吗?像这样的东西:

    import subprocess

process = subprocess.Popen(['python', 'manage.py','process_tasks'], stdout=subprocess.PIPE, stderr=subprocess.PIPE)

最佳答案

运行单独的进程以在后台运行任务不是必需的,但有好处且有帮助。

当您运行服务器时,会创建一个进程 - 运行 ps aux | grep runserver - 负责处理网络请求。当你说你想在后台运行某些任务时,它隐含地意味着你想要一个单独的进程来执行这些任务。这就是 celery 等异步任务工具的用武之地。

您也可以像您所说的那样自己生成一个单独的进程:

import subprocess

process = subprocess.Popen(['python', 'manage.py','process_tasks'], stdout=subprocess.PIPE, stderr=subprocess.PIPE

如果您只想并行运行一两个小任务,这种方法也完全没问题。但是,当您有大量在后台运行的复杂任务时,您会希望妥善管理它们。此外,如果出现问题,您还需要能够调试这些任务。稍后,您将需要更多地了解所有后台任务中发生的事情、它们的状态等。这就是 celery 可以帮助您的地方。它会给你装饰的方法来为你处理所有这些事情。然后你只需要担心你的业务逻辑

关于python - 我可以在不启动并行进程的情况下在 Django 中运行后台进程吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44172183/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com