2017-02-06 130 views
1

我想运行nginx的Django的我遵循了这一instructions的Django nginx的uwsgi坏网关502

的/ etc/nginx的/网站可用/ cartoview_one

upstream django { 
    server unix:///root/cartoview_project/mysite.sock; # for a file socket } 

server { 
    listen  80; 
    server_name xx.xx.xx.xx; 
    charset  utf-8; 

    # max upload size 
    client_max_body_size 2048M; # adjust to taste 

    # Django media 
    location /media { 
     alias /root/cartoview_project/uploaded; 
    } 

    location /static { 
     alias /root/cartoview_project/static; 
    } 
    location/{ 
     uwsgi_pass django; 
     include  /root/cartoview_project/uwsgi_params; # the uwsgi_params file you installed 
    } 
} 

然后创建符号链接使用:

sudo ln -s /etc/nginx/sites-available/cartoview_one /etc/nginx/sites-enabled 

并在项目文件夹mysite_uwsgi.ini

[uwsgi] 
project = cartoview_project 
chdir   = /root/cartoview_project 
module   = %(project).wsgi:application 
home   = /root/env 
master   = true 
processes  = 10 
socket   = /root/cartoview_project/mysite.sock 
chmod-socket = 666 
vacuum   = true 
http-socket = 0.0.0.0:80 

项目结构:

. 
|-- apps 
|-- cartoview_project 
| |-- __init__.py 
| |-- __init__.pyc 
| |-- local_settings.py 
| |-- local_settings.pyc 
| |-- local_settings.py.sample 
| |-- settings.py 
| |-- settings.pyc 
| |-- urls.py 
| |-- wsgi.py 
| `-- wsgi.pyc 
|-- default_oauth_apps.json 
|-- initial_data.json 
|-- manage.py 
|-- mysite_uwsgi.ini 
`-- uwsgi_params 

当我试着使用MYIP此消息访问网站出现:

502网关错误

的nginx/1.10。 0(Ubuntu)

error.log中:

2017年2月6日9时46分41秒[暴] 6867#6867:* 1 connect()以 UNIX:///根/ cartoview_project/mysite的。 socks失败(13: 权限被拒绝),同时连接到上游,客户端: xx.xx.xxx.xxx,服务器:xxx.xxx.xxx.xxx,请求:“GET/HTTP/1.1”,上游: “uwsgi :// UNIX:///root/cartoview_project/mysite.sock:”主持人: “xxx.xxx.xxx.xxx”

更新:

我删除http-socket并运行以下命令/root/env/bin/uwsgi --ini mysite_uwsgi.inimysite.sock出现在项目中,然后重新启动nginx,但没有任何更改。

:~/cartoview_project# stat mysite.sock 
    File: 'mysite.sock' 
    Size: 0    Blocks: 0   IO Block: 4096 socket 
Device: 802h/2050d  Inode: 17172079 Links: 1 
Access: (0666/srw-rw-rw-) Uid: ( 0/ root) Gid: ( 0/ root) 
Access: 2017-02-06 10:44:56.188168371 +0100 
Modify: 2017-02-06 10:44:56.188168371 +0100 
Change: 2017-02-06 10:44:56.188168371 +0100 
Birth: - 

机:VPS(Ubuntu的16.04)用户:根

解决: 通过改变include /root/cartoview_project/uwsgi_paramsinclude /etc/nginx/uwsgi_params;

+0

您可以使用此命令在uwsgi uwsgi --http 0.0.0.0:8134 --wsgi-file UniservedWebsite/wsgi.py&'生产后台运行您的应用程序,并将您的nginx引用到'0.0.0.0: 8134'并添加'http-timeout' –

回答

0

从描述,它看起来像你还没有运行uwsgi过程 - 此时的502错误意味着nginx正确传递响应,但没有任何连接,或者它没有得到正确的响应。

which uwsgi将为您提供相应uwsgi的路径(如果您正在运行,请在virtualenv中执行此操作)。

例如

/root/cartoview_project/uwsgi --ini mysite_uwsgi.ini

你应该采取的http-socket配置变量出uwsgi的虽然 - nginx的正在侦听端口80,并使其通过由您uwsgi应用程序创建了.sock文件。

+0

我删除了'http-socket'并运行以下命令'/ root/env/bin/uwsgi --ini mysite_uwsgi.ini'并重新启动nginx但没有任何更改注意:'mysite.sock '出现在项目 – Hisham

+0

是否wsgi肯定在运行?入住顶部。如果你在'mysite.sock'文件上运行'stat',你得到了什么用户/组和权限? – Withnail

+0

看一下http://imgur.com/a/IJpAf – Hisham