django项目部署 使用uwsgi + nginx 实现django项目的部署
目录
一、Django配置
1.settings.py配置
复制全局settings.py配置文件(或者直接修改),创建一个名为deploy_settings.py的副本,修改DEBUG
=False。
DEBUG = False
# 填写你自己的ip和域名 # 注意,这里要写上允许谁访问的ip地址,不然就访问不了,踩了个大坑,长记性了
ALLOWED_HOSTS = ["yan.long920.cn", "localhost", "127.0.0.1", '112.74.160.252']
2.wsgi.py配置
修改settings.py同目录下的wsgi.py文件
import os
from django.core.wsgi import get_wsgi_application
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'tznewblog.deploy_settings')
application = get_wsgi_application()
二.生成requirement.txt文件
# 在xshell中生成requirements.txt文件(将项目中安装的包,存放到requirements.txt文件中)
pip freeze > requirements.txt
三. 上传代码到服务器
四、 安装requirements.txt 对应的包
安装包之前先创建一个虚拟环境
pip install -r requirements.txt
五. uwsgi的安装和测试
# 进入到虚拟环境 安装uwsgi
workon dj_pro
pip install uwsgi
测试uwsgi是否安装成功文件代码:
# 测试py文件
# test_uwsgi.py
def application(env, start_response):
start_response('200 OK', [('Content-Type','text/html')])
return [b"Hello World"] # python3
#return ["Hello World"] # python2
运行uwsgi:
uwsgi --http :8101 --wsgi-file test_uwsgi.py
测试uwsgi是否运行正常:
curl 127.0.0.1:8101
# 如下就是正常的
[root@zhenzi0322 ~]# curl http://127.0.0.1:8101
Hello World[root@zhenzi0322 ~]#
六. uwsgi 文件配置
1. uwsgin_conf.ini
文件代码 在项目根目录中创建deploy目录,新建uwsgi_conf.ini文件。
[uwsgi]
# ip和端口
# nginx连接
socket=127.0.0.1:8101
#http=127.0.0.1:8101 # socker 和 http 两者只能设置一个, 如果设置的是http, 那么此时在服务器上curl http://127.0.0.1:8101 就能够接收到返回结果, 如果是socker的话,那么还需要搭配nignx来使用
#http=0.0.0.0:8101
# 指定项目的根目录
chdir=/home/cheng/django_deploy/tznewblog/
# 项目中 wsgi.py 文件的相对目录,相对于项目根目录
wsgi-file=tznewblog/wsgi.py
# 进程数
processes=1
# 线程数
threads=1
# uwsgi服务器角色
# 这里设置为主
master=True
# 存放进程编号的文件
pidfile=uwsgi.pid
# 日志文件,因为uwsgi可以脱离终端在后台运行,日志看不见,以前的runserver是依赖终端的
# 记得在当前目录下创建logs文件夹
daemonize=logs/uwsgi.logs
# 指定虚拟环境所在目录,绝对路径
virtualenv=/home/cheng/.virtualenvs/cheng_dj_deploy
2.uwsgi的运行及停止
# 启动uwsgi
uwsgi --ini uwsgi_conf.ini
# 停止uwsgi
uwsgi --stop uwsgi.pid
七、直接在服务器上安装nginx (后面会介绍在docker中安装和启动)
1. 安装
# 安装nginx
sudo apt-get update
sudo apt-get install nginx
# nginx 安装后一般自动启动
sudo service nginx status # 查看nginx状态
# 默认开启80端口,可以查看一下是否提供web服务
curl -I 127.0.0.1
2. nginx命令 (使用管理员权限)
1. 启动nginx: nginx
2. 停止nginx: nginx -s stop
3. 重新加载nginx配置文件(一般修改nginx配置文件的时候用): nginx -s reload
# 一般我就用上面这几个命令
dongcheng@long:~$ sudo nginx -h
nginx version: nginx/1.15.5 (Ubuntu)
Usage: nginx [-?hvVtTq] [-s signal] [-c filename] [-p prefix] [-g directives]
Options:
-?,-h : this help
-v : show version and exit
-V : show version and configure options then exit
-t : test configuration and exit
-T : test configuration, dump it and exit
-q : suppress non-error messages during configuration testing
-s signal : send signal to a master process: stop, quit, reopen, reload
-p prefix : set prefix path (default: /usr/share/nginx/)
-c filename : set configuration file (default: /etc/nginx/nginx.conf)
-g directives : set global directives out of configuration file
3.除了nginx本身提供的命令,我们还可以通过信号控制nginx
# 1. QUIT: 优雅的关闭进程,即等请求结束后再关闭
# 2. HUP: 改变配置文件,平滑的重读配置文件
# 3. USR1: Reopen the log files 重读日志,在日志按月/日分割时有用
# 4. USR2: Upgrade Executable on the fly 平滑的升级
# 5. WINCH: Gracefully shutdown the worker processes 优雅关闭旧的进程(配合USR2来进行升级)
# 一般情况下只会用到QUIT 和 HUP
使用方法: 首先要知道nginx的进程号, (所以可能还是nginx本身提供的命令好用)
ps -aux|grep nginx # 查nginx 的进程号, 比如 nginx 的进程号为4873
具体语法:
kill -信号选项 nginx的主进程号
kill -HUP 4873 # 相当于nginx -s reload
kill -quit 4873
kill -9 4873
# 可能通过查看nginx.pid来获得nginx的进程号,从而省去ps -aux|grep nginx查找nginx进程号的步骤
kill -信号控制 `cat /run/nginx.pid` # nginx的pid进程号一般存放在这里
kill -USR1 `cat /run/nginx.pid`
dongcheng@long:/run$ sudo kill -hup `cat nginx.pid`
4. 关于更多nginx知识
1. nginx介绍
- Mainline version 开发版
- Stable version 稳定版
- Legacy version 历史版本
安装好nginx后,查看nginx版本: nginx -v
2. nginx安装目录
路径 | 类型 | 作用 |
---|---|---|
/etc/nginx /etc/nginx/nginx.conf /etc/nginx/conf.d /etc/nginx/conf.d/default.conf /etc/nginx/sites-available /etc/nginx/sites-enabled |
配置文件 | nginx主配置文件 |
/etc/nginx/fastcgi_params /etc/nginx/scgi_params /etc/nginx/uwsgi_params |
配置文件 | fastcgi 、scgi 、 uwsgi配置文件 |
/etc/nginx/win-utf /etc/nginx/koi-utf /etc/nginx/koi-win |
配置文件 | nginx编码转换映射文件 |
/etc/nginx/mime.types | 配置文件 | htttp协议的Content-Type与扩展名 |
/usr/lib/systemd/systemd/nginx.service | 配置文件 | 配置系统守护进程管理器 |
/etc/logrotate.d/nginx | 配置文件 | nginx⽇志轮询,⽇志切割 |
/usr/sbin/nginx /usr/sbin/nginx-debug |
命令 | nginx终端管理命令 |
/etc/nginx/modules /usr/lib/nginx 可能也为/usr/lib64/nginx /usr/lib/nginx/modules |
目录 | nginx模块目录 |
/usr/share/nginx /usr/share/html /usr/share/html/index.html /var/www/html/ |
目录 | nginx默认站点目录 |
/var/log/nginx | 目录 | nginx的日志目录 |
/run/nginx.pid | 文件 | nginx 运行的端口号 |
3. nginx编译参数
查看nginx编译参数 命令:nginx -V
4. HTTP 状态码
- 301 永久移动。被请求的资源已被永久移动到指定位置
- 302 请求的资源现在临时从不同的URL响应请求
- 305 使用代理。被请求的资源必须通过指定的代理才能被访问
- 307 临时跳转。被请求的资源在临时从不同的URL响应请求
- 400 错误请求
- 402 需要付款。该状态码是为了将来可能的需求而预留的,用于一些数字货币或者是微支付
- 403 禁止访问。服务器已经理解请求,但是拒绝执行它
- 404 找不到对象。请求失败,资源不存在
- 406 不可接受的
- 408 请求超时
- 409 冲突。由于和被请求的资源的当前状态之间存在冲突,请求无法完成
- 410 遗失的。被请求的资源在服务器上已经不再可用,而且没有任何已知的转发地址
- 413 响应实体太大。服务器拒绝处理当前请求,请求超过服务器所能处理和允许的最大值
- 417 期望失败。在请求头Expect中指定的预期内容无法被服务器满足
- 418 我是一个茶壶。超文本咖啡罐控制协议,但是并没有被实际的HTTP服务器实现
- 420 方法失败
- 422 不可处理的实体。请求格式正确,但是由于含有语义错误,无法响应
- 500 服务器内部错误。服务器遇到了一个未曾预料的头部,导致了它无法完成对请求的处理
- 502 请求后端失败
- 504 请求成功,但是影响超时
5. nginx 主配置文件
nginx主配置文件/etc/nginx/nginx.conf是一个纯文本类型的文件,整个配置文件是以区块的形式组织的。一般,每个区块以一对大括号{}
来表示开始与结束。
小知识
- 动态查看日志
fail -f /var/log/nginx/access.log
# 使用fail命令来查看
八、django项目的nginx配置文件
- 创建/etc/nginx/conf.d/nginx_uwsgi.conf文件:
# 我的nginx_uwsgi.conf配置
upstream chengBlog {
# 此处为uwsgi运行的ip地址和端口号
server 127.0.0.1:8101;
}
server {
# 监听端口
listen 80;
# 服务器域名或者ip地址
server_name yan.long920.cn 112.74.160.252 localhost;
# 编码
charset utf-8;
# 文件最大上传大小
client_max_body_size 75M;
# 媒体文件
location /media {
alias //home/cheng/django_deploy/tznewblog/media;
}
# 静态文件
location /static {
alias //home/cheng/django_deploy/tznewblog/static;
}
# 主目录, 交给uwsgi处理, nginx 只处理静态文件目录
location / {
uwsgi_pass chengBlog;
include /www/server/nginx/conf/uwsgi_params;
}
}
- 如果如果出现静态文件无法访问: 即出现: 403 Forbade 的形式
修改sudo vim /etc/nginx/nginx.conf
第一行开头修改用户,将www-data改为你当前的用户
# 在我ubuntu 中:
# user www-data
user pyvip;
# 在centos7中:
# user www www
user root
- 查看nginx 配置文件是否正确(查看有无语法错误)
# sudo nginx -t -c /etc/nginx/nginx.conf
sudo nginx -t # 一般我使用这条命令
# 打印如下内容,则没问题
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
# 重新加载配置
# sudo nginx -s reload -c /etc/nginx/nginx.conf
sudo nginx -s reload # 一般我使用这条命令, 这两条命令都应该是加不加参数都无所谓
centos7 下创建用户部署django项目
- 创建
cheng
这个用户并为其设置密码:
useradd cheng -g root -m # 创建cheng用户
password cheng # 为cheng 设置密码
su cheng # 切换到cheng用户
- 为 cheng 添加 sudo 权限(在root用户下完成)
若执行sudo命令的用户没有sodu权限,则会报以下错误:
cheng is not in the sudoers file.This incident will be reported
准备工作:
ls -l /etc/sudoers 查看文件权限
chmod u+w /etc/sudoers 修改文件权限为可编辑
# 首先切换为root用户
su root
# 修改sudoers文件
vim /etc/sudoers
# 找到: root All=(ALL) ALL 这一行, 在下一行添加上相应的用户即可
## Allow root to run any commands anywhere; 若要给cheng用户增加sudo权限,需要增加如下一行
root ALL=(ALL) ALL
cheng ALL=(ALL) ALL
修改完成后,记得将文件权限改回只读:
chmod u-w /etc/sudoers 修改文件权限为只读
ls -l /etc/sudoers 查看文件权限
至此就为 cheng 这个用户添加上了sudo权限, 该用户可以使用sudo 来提升至管理员权限了
搭建 cheng 用户的虚拟环境
workon
mkvirtualenv
...
此时你会发现在root用户下管用的这几个命令在cheng这个用户下是找不到的(提示你没有命令没找到), # 刚创建好的这个用户是没有: workon mkvirtualenv 等命令的, 还需要我们去配置
- 去编辑
~/.bashrc
在最后添加上这几句话 # 家目录下的这一隐藏文件
export WORKON_HOME=$HOME/.virtualenvs
export PROJECT_HOME=$HOME/workspace
source /usr//bin/virtualenvwrapper.sh # 注意 virtualenvwrapper.sh 的位置, 有可能不是这个位置
# find / -name virtualenvwrapper.sh # 查找virtualenvwrapper.sh 这个文件的位置
- 编辑上述文件并保存好后,运行如下命令使配置立即生效:
source ~/.bashrc
此时, 再输入 workon 等命令就可以了
创建 cheng 用户的 python3 虚拟环境
mkvirtualenv -p python3 cheng_py3
至此剩下的步骤都是一样的了