Django / nginx / uwsgi出现502错误

时间:2015-11-14 15:46:05

标签: django ubuntu nginx uwsgi digital-ocean

我真的很紧张,因为我试图让这个网站在我的ubuntu服务器上运行。我只是一个试图自己主持事情的前锋。我想我几乎把它搞定了。但访问域时仍然遇到502错误的网关错误。

这是我的项目树:

-- var
    -- www
        -- stacaravanverhuurgroesbeek
            |-- env/
            |-- logs/
                |-- access.log
                |-- error.log
                `-- uwsgi.log
            |-- conf/
            |   |-- stacaravanverhuurgroesbeek.sock
            |   `-- uwsgi.ini
            `-- public/
                |-- manage.py
                |-- media/
                |-- project.db
                |-- requirements.txt
                |-- static/
                `-- website/
                    |-- dev/
                    |-- gulp/
                    |-- gulpfile.js
                    |-- package.json
                    |-- settings.py
                    |-- static/
                    |-- templates/
                    |-- urls.py
                    `-- wsgi.py

我的uwsgi ini档案: /var/www/stacaravanverhuurgroesbeek/conf/uwsgi.ini

[uwsgi]
# variables
projectname = stacaravanverhuurgroesbeek
projectdomain = stacaravanverhuurgroesbeek.nl 
base = /var/www/stacaravanverhuurgroesbeek

# config
chdir = %(base)/public
home = %(base)/env
wsgi-file = %(base)/public/website/wsgi.py

master = True
processes = 5

socket = %(base)/conf/%(projectname).sock
vacuum = true
die-on-term = true

logto = %(base)/logs/uwsgi.log

我的nginx配置: /etc/nginx/sites-available/stacaravanverhuurgroesbeek

server {
    listen 80;
    server_name stacaravanverhuurgroesbeek.nl www.stacaravanverhuurgroesbeek.nl;

    root /var/www/stacaravanverhuurgroesbeek/;
    access_log /var/www/stacaravanverhuurgroesbeek/logs/access.log;
    error_log /var/www/stacaravanverhuurgroesbeek/logs/error.log;

    location /static/ {
        root /var/www/stacaravanverhuurgroesbeek/public/static/;
    }

    location /media/ {
        root /var/www/stacaravanverhuurgroesbeek/public/media/;
    }

    location / {
        include         uwsgi_params;
        uwsgi_pass      unix:///var/www/stacaravanverhuurgroesbeek/conf/stacaravanverhuurgroesbeek.sock;
    }
}

我还将此文件符号链接到sites-enabled

我的启动脚本: /etc/init/uwsgi.conf

# Emperor uWSGI script

description "uWSGI Emperor"
start on runlevel [2345]
stop on runlevel [!2345]

setuid bastard
setgid bastard

exec uwsgi --master --emperor /etc/uwsgi/vassals

每当我改变一些东西时,我重新启动了nginx和uwsgi,没有效果。

我真的希望有人能够在我的设置中看到问题所在。

1 个答案:

答案 0 :(得分:0)

也许您应该在Nginx配置中设置上游,因为您要将所有请求代理到uWSGI。 E.g:

upstream uwsgi_app {
    server unix:///path/to/your/mysite/mysite.sock; # взаимодействие  
}

server {
    ...
    location / {
        uwsgi_pass uwsgi_app;
        include uwsgi_params;
    }
    ...
}

如果它不起作用,请同时提供uWSGI日志以确保reqquest实际到达uWSGI并且没有发生错误。