ubuntu上使用Nginx部署Django

2016-09-23 11:09:18 10248

1. 运行开发服务器测试

1
2
cd zqxt # 进入项目 zqxt 目录
python manage.py runserver

运行开发服务器测试,确保开发服务器下能正常打开网站。

2. 安装 nginx 和 需要的包

2.1 安装 nginx 等软件

ubuntu / Linux Mint 等,下面简写为 (ubuntu):

1
sudo apt-get install python-dev nginx

centos / Fedora/ redhat 等,下面简写为 (centos)

1
2
sudo yum install epel-release
sudo yum install python-devel nginx

2.2 安装 supervisor, 一个专门用来管理进程的工具,我们用它来管理 gunicorn/uwsgi

1
sudo pip install supervisor

Ubuntu用户 请直接看 3,以下是CentOS 注意事项:

CentOS下,如果不是非常懂 SELinux 和 iptables 的话,为了方便调试,可以先临时关闭它们,如果发现部署了之后出不来结果,可以临时关闭测试一下,这样就知道是不是 SELinux 和 iptables 的问题

CentOS 7 iptables如何使用http://www.landui.com/questions/24756240/


将 SELinux 设置为宽容模式,方便调试:

1
sudo setenforce 0

防火墙相关的设置:

1
2
3
4
5
可以选择临时关闭防火墙
sudo service iptables stop
 
或者开放一些需要的端口,比如 80
sudo iptables -A INPUT -p tcp -m tcp --dport 80 -j ACCEPT

上面的两条命令,如果是 CentOS 7 用

1
2
3
4
5
6
临时关闭防火墙
sudo systemctl stop firewalld
 
或者 开放需要的端口
sudo firewall-cmd --zone=public --add-port=80/tcp --permanent
sudo firewall-cmd --reload

备注:由于我还没有用 最新版本的 Fedora ,新版 Fedora 需要用 dnf 来安装包,有需求的同学自测,可以参考这里

3. 使用 gunicorn / uwsgi 来部署 (二选一)

注意:以下为二选一,不需要两个都用

3.1 使用 gunicorn(纯Python实现的包):

1
sudo pip install gunicorn

在项目目录下运行下面的命令进行测试:

1
gunicorn -w4 -b0.0.0.0:8001 zqxt.wsgi

-w 表示开启多少个worker,-b 表示要使用的ip和port,我们这里用的是 8001,0.0.0.0代表监控电脑的所有 ip。


如果使用了 virtualenv 可以这样

1
/path/to/env/bin/gunicorn --chdir /path/to/project --pythonpath /path/to/env/ -w4 -b0.0.0.0:8017 project.wsgi:application

用 --pythonpath 指定依赖包路径,多个的时候用逗号,隔开,如:'/path/to/lib,/home/tu/lib'

3.2 使用 uwsgi(纯C语言实现的包):

安装 uwsgi

1
sudo pip install uwsgi

使用 uwsgi 运行项目

1
uwsgi --http :8001 --chdir /path/to/project --home=/path/to/env --module project.wsgi

这样就可以跑了,--home 指定virtualenv 路径,如果没有可以去掉。project.wsgi 指 project/wsgi.py 文件

如果提示端口已经被占用:

1
2
probably another instance of uWSGI is running on the same address (:8002).
bind(): Address already in use [core/socket.c line 764]

这时可以把相关的进程 kill 掉:

按照端口进行查询:

1
lsof -i :8002

可以查出:

1
2
3
COMMAND  PID USER   FD   TYPE             DEVICE SIZE/OFF NODE NAME
uwsgi   2208   tu    4u  IPv4 0x53492abadb5c9659      0t0  TCP *:teradataordbms (LISTEN)
uwsgi   2209   tu    4u  IPv4 0x53492abadb5c9659      0t0  TCP *:teradataordbms (LISTEN)

这时根据 PID 可以用下面的命令 kill 掉相关程序:

1
sudo kill -9 2208 2209

按照程序名称查询:

1
ps aux | grep uwsgi

4. 使用supervisor来管理进程

安装 supervisor 软件包

1
(sudo) pip install supervisor

生成 supervisor 默认配置文件,比如我们放在 /etc/supervisord.conf 路径中:

1
(sudo) echo_supervisord_conf > /etc/supervisord.conf


打开 supervisor.conf 在最底部添加(每一行前面不要有空格,?止报错):

1
2
3
4
5
6
7
[program:zqxt]
command=/path/to/uwsgi --http :8003 --chdir /path/to/zqxt --module zqxt.wsgi
directory=/path/to/zqxt
startsecs=0
stopwaitsecs=0
autostart=true
autorestart=true

command 中写上对应的命令,这样,就可以用 supervisor 来管理了。


启动 supervisor

1
(sudo) supervisord -c /etc/supervisord.conf


重启 zqxt 程序(项目):

1
(sudo) supervisorctl -c /etc/supervisord.conf restart zqxt


启动,停止,或重启 supervisor 管理的某个程序 或 所有程序:

1
(sudo) supervisorctl -c /etc/supervisord.conf [start|stop|restart] [program-name|all]


以 uwsgi 为例,上面这样使用一行命令太长了,我们使用 ini 配置文件来搞定,比如项目在 /home/tu/zqxt 这个位置,

在其中新建一个 uwsgi.ini 全路径为 /home/tu/zqxt/uwsgi.ini

1
2
3
4
5
6
7
8
9
10
11
[uwsgi]
socket = /tmp/zqxt.sock
chdir=/ho

提交成功!非常感谢您的反馈,我们会继续努力做到更好!

这条文档是否有帮助解决问题?

非常抱歉未能帮助到您。为了给您提供更好的服务,我们很需要您进一步的反馈信息:

在文档使用中是否遇到以下问题: