7

问题

上传 1-2mb 文件可以正常工作。当我尝试上传 16mb 文件时,几秒钟后出现 502 错误

更详细:

  1. 我点击“上传”
  2. 谷歌浏览器上传文件(左下角上传状态从 0% 变为 100%)
  3. 状态更改为“等待主机”,其中主机是我的站点主机名
  4. 半分钟后服务器返回“502 Bad Gateway”

我的观点:

def upload(request):
    if request.method == 'POST':
        f = File(data=request.FILES['file'])
        f.save()
        return redirect(reverse(display),  f.id)
    else:
        return render('filehosting_upload.html', request)

render(template, request [,data]) 是我自己处理一些 ajax 东西的速记;

filehosting_upload.html:_

{% extends "base.html" %}
{% block content %}
    <h2>File upload</h2>
    <form action="{% url nexus.filehosting.views.upload %}" method="post" enctype="multipart/form-data">
        {% csrf_token %}
        <input type="file" name="file">
        <button type="submit" class="btn">Upload</button>
    </form>
{% endblock %}

日志和规格

我在日志中找不到任何信息。

版本:

  • Django==1.4.2
  • Nginx==1.2.1
  • 独角兽==0.17.2

命令行参数

command=/var/www/ernado/data/envs/PROJECT_NAME/bin/gunicorn -b localhost:8801 -w 4 PROJECT_NAME:application

相关位置的 Nginx 配置:

   location /files/upload {
    client_max_body_size 100m;
    proxy_pass http://HOST;
    proxy_connect_timeout 300s;
    proxy_read_timeout 300s;
   }

Nginx 日志条目(更改了 MY_IP 和 HOST)

2013/03/23 19:31:06 [error] 12701#0: *88 upstream prematurely closed connection while reading response header from upstream, client: MY_IP, server: HOST, request: "POST /files/upload HTTP/1.1", upstream: "http://127.0.0.1:8801/files/upload", host: "HOST", referrer: "http://HOST/files/upload"

Django 日志

2013-03-23 19:31:06 [12634] [CRITICAL] WORKER TIMEOUT (pid:12829)
2013-03-23 19:31:06 [12634] [CRITICAL] WORKER TIMEOUT (pid:12829)
2013-03-23 19:31:06 [13854] [INFO] Booting worker with pid: 13854

问题)

  1. 如何解决?
  2. 没有nginx上传模块可以解决这个问题吗?

更新 1 尝试了建议的配置

 gunicorn --workers=3 --worker-class=tornado  --timeout=90 --graceful-timeout=10 --log-level=DEBUG --bind localhost:8801 --debug

现在对我来说很好。

4

3 回答 3

4

我使用该参数运行我的 gunicorn,尝试:

python manage.py run_gunicorn --workers=3 --worker-class=tornado  --timeout=90 --graceful-timeout=10 --log-level=DEBUG --bind 127.0.0.1:8151 --debug

或者如果您以不同的方式运行,您可以使用该选项运行

于 2013-03-23T19:05:58.700 回答
3

对于大文件处理,您应该使用worker-class。我在 python 3.7 中使用 gevent 时也遇到了一些麻烦,最好使用 3.6。

Django,Python 3.6 示例:

安装

pip install gevent

gunicorn --chdir myApp myApp.wsgi --workers 4 --worker-class=gevent --bind 0.0.0.0:80 --timeout=90 --graceful-timeout=10
于 2018-08-10T16:32:49.437 回答
1

您需要使用其他工作类型类,如geventtornado之类的异步类,请参阅此以获得更多解释:第一个解释:

如果您希望您的应用程序代码在请求处理期间可能需要长时间暂停,您可能还需要安装 Eventlet 或 Gevent

第二个 :

默认同步工作程序假定您的应用程序在 CPU 和网络带宽方面是资源受限的。一般来说,这意味着您的应用程序不应该做任何花费未定义时间的事情。例如,对 Internet 的请求符合此标准。在某些时候,外部网络会出现故障,导致客户端堆积在您的服务器上。

于 2014-05-07T10:31:53.073 回答