本文主要讲解 Nginx + uwsgi socket 的方式来部署 Django,比 Apache mod_wsgi 要复杂一些,但这是目前主流的方法。
推荐:使用Code Studio 云端开发,新人更有免费一个月云主机,可以用来实战体验本节的部署!
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, 一个专门用来管理进程的工具,我们用它来管理 uwsgi 进程
1 |
sudo pip install supervisor
|
Ubuntu用户 请直接看 3,以下是CentOS 注意事项:
CentOS下,如果不是非常懂 SELinux 和 iptables 的话,为了方便调试,可以先临时关闭它们,如果发现部署了之后出不来结果,可以临时关闭测试一下,这样就知道是不是 SELinux 和 iptables 的问题
CentOS 7 iptables如何使用:http://stackoverflow.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. 使用 uwsgi 来部署
安装 uwsgi
1 |
sudo pip install uwsgi --upgrade
|
使用 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
|
补充内容:
1 2 3 4 |
sudo pip install gunicorn
在项目目录下运行下面的命令进行测试:
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'
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 12 13 |
[uwsgi]
socket = /home/tu/zqxt/zqxt .sock
chdir = /home/tu/zqxt
wsgi- file = zqxt /wsgi .py
touch -reload = /home/tu/zqxt/reload
processes = 2
threads = 4
chmod -socket = 664
chown -socket = tu:www-data
vacuum = true
|
注意上面的 /home/tu/zqxt/zqxt.sock ,一会儿我们把它和 Nginx 关联起来。
在项目上新建一个空白的 reload 文件,只要 touch 一下这个文件(touch reload) 项目就会重启。
注意:不建议把 sock 文件放在 /tmp 下,比如 /tmp/xxx.sock (不建议)!有些系统的临时文件是 namespaced 的,进程只能看到自己的临时文件,导致 Nginx 找不到 uwsgi 的 socket 文件,访问时显示502,Nginx 的 access log 中显示 unix: /tmp/xxx.sock Failed (2: No such file or directory),所以部署的时候建议用其它目录来放 socket 文件,比如放在运行Nginx用户目录中,也可以专门弄一个目录来存放 sock 文件,比如 /tmp2/
1 2 |
sudo mkdir -p /tmp2/ && sudo chmod 777 /tmp2/
然后可以用 /tmp2/zqxt .sock 这样的路径了
|
修改 supervisor 配置文件中的 command 一行:
1 2 3 4 |
[program:zqxt]
command=/path/to/uwsgi --ini /home/tu/zqxt/uwsgi.ini
directory=/path/to/zqxt
startsecs=0
|
然后重启一下 supervisor:
1 2 3 |
( sudo ) supervisorctl -c /etc/supervisord .conf restart zqxt
或者
( sudo ) supervisorctl -c /etc/supervisord .conf restart all
|
5. 配置 Nginx
新建一个网站 zqxt
1 |
sudo vim /etc/Nginx/sites-available/zqxt .conf
|
写入以下内容:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
server {
listen 80;
server_name www.ziqiangxuetang.com;
charset utf-8;
client_max_body_size 75M;
location /media {
alias /path/to/project/media;
}
location /static {
alias /path/to/project/static;
}
location / {
uwsgi_pass unix:///home/tu/zqxt/zqxt.sock;
include /etc/Nginx/uwsgi_params;
}
}
|
激活网站:
1 |
sudo ln -s /etc/Nginx/sites-available/zqxt .conf /etc/Nginx/sites-enabled/zqxt .conf
|
测试配置语法问题
1 |
sudo service Nginx configtest 或 /path/to/Nginx -t
|
重启 Nginx 服务器:
1 |
sudo service Nginx reload 或 sudo service Nginx restart 或 /path/to/Nginx -s reload
|
一些有用的参考教程:
Django 官网部署教程:
https://docs.djangoproject.com/en/dev/howto/deployment/wsgi/gunicorn/
https://docs.djangoproject.com/en/dev/howto/deployment/wsgi/uwsgi/
Nginx 与 socket
防火墙:
centos 7 FireWalld: http://stackoverflow.com/questions/24756240/how-can-i-use-iptables-on-centos-7
ubuntu ufw 防火墙:http://wiki.ubuntu.org.cn/Ufw%E4%BD%BF%E7%94%A8%E6%8C%87%E5%8D%97
uwsgi ini 配置文件:http://uwsgi-docs.readthedocs.org/en/latest/tutorials/Django_and_nginx.html#configuring-uwsgi-to-run-with-a-ini-file
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。