首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在django项目中运行nginx和uwsgi需要时间。

在django项目中运行nginx和uwsgi需要时间。
EN

Stack Overflow用户
提问于 2016-08-11 09:04:21
回答 2查看 776关注 0票数 4

我正在使用python的多处理模块启动一个进程。此过程由django项目中发送的post请求调用。当我使用开发服务器(python manage.py runserver)时,post请求无需花时间启动进程并立即完成。

我使用nginx和uwsgi在生产上部署了这个项目。

现在,当我发送相同的帖子请求时,大约需要5-7分钟才能完成请求。这种情况只发生在我要开始处理的那些帖子请求中。其他职位要求工作良好。

这一延误的原因是什么?我怎么才能解决这个问题?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-08-23 06:04:35

我想出了一个解决办法(不知道这是否符合答案)。我将后台进程写成了数据库中的作业,并使用cron作业来检查是否有任何待定作业,如果有,cron将启动该作业的后台进程并退出。

每分钟运行一次,这样就不会有太多的延误了。这有助于提高性能,因为它帮助我执行像这样的繁重任务,以独立于主应用程序运行。

票数 0
EN

Stack Overflow用户

发布于 2016-08-16 12:53:28

基本上,后台处理需要在WSGI应用程序模块之外启动。

在WSGI中,python webapp进程将开始处理请求,请求的数量因配置而异。如果该进程产生一个新的进程,该进程将阻止WSGI进程处理新的请求,使服务器阻塞并等待它完成后再处理新的请求。

我建议您使用WSGI应用程序模块中的共享队列来输入在WSGI应用程序模块之外启动的进程。就像下面这样。这将为webapp模块之外的每个WSGI进程启动一个新处理器,以避免阻塞请求。

your_app/webapp.py

代码语言:javascript
运行
复制
from . import bg_queue
def post():
    # Webapp POST code here
    bg_queue.add(<task data>)

your_app/processor.py

代码语言:javascript
运行
复制
from multiprocessing import Process

class Consumer(Process):
    def __init__(self, input_q):
        self.input_q = input_q

    def run(self):
        while True:
            task_data = input_q.get()
            <process data>

your_app/__init__.py

代码语言:javascript
运行
复制
from .processor import Consumer
bg_queue = Queue()

consumer = Consumer(bg_queue)
consumer.daemon = True
consumer.start()
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38891879

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档