Django + Uwsgi + Nginx 的生产环境部署
使用runserver可以使我们的django项目很便捷的在本地运行起来,但这只能在局域网内访问,如果在生产环境部署django,就要多考虑一些问题了。
比如静态文件处理,安全,效率等等,
本篇文章总结归纳了一下基于uwsgi+Nginx下django项目生产环境的部署
环境准备:
1.确保有一个能够用runserver正常启动的django项目 2.项目已上传到linux
3.linux上已部署好python环境,且已安装好项目所需的模块
uwsgi的安装
pip install uwsgi
基于uwsgi+django的实现
第一: 上传Django项目文件到linux上,并进入项目目录中

第二: 通过命令行启动
uwsgi --http 192.168.31.123:8080 --file teacher/wsgi.py --static-map=/static=static
参数说明:
-- http 这个就和runserver一样指定IP 端口
-- file 这个文件就里有一个反射,如果你在调用他的时候没有指定Web Server就使用默认的
-- static 做一个映射,指定静态文件

此时,访问http://192.168.2.108:8080/

2.使用uwsgi配置文件启动django项目
第一步:在django项目同级目录创建script目录,用于存放配置脚本等

第二步:进入/script目录,创建一个uwsgi.ini文件
编辑uwsgi.ini文件内容如下:
# uwsig使用配置文件启动 [uwsgi] # 项目目录 chdir=/opt/proj/teacher/ # 指定项目的application module=teacher.wsgi:application # 指定sock的文件路径 socket=/opt/proj/script/uwsgi.sock # 进程个数 workers=5 pidfile=/opt/proj/script/uwsgi.pid # 指定IP端口 http=192.168.2.108:8080 # 指定静态文件 static-map=/static=/opt/proj/teacher/static # 启动uwsgi的用户名和用户组 uid=root gid=root # 启用主进程 master=true # 自动移除unix Socket和pid文件当服务停止的时候 vacuum=true # 序列化接受的内容,如果可能的话 thunder-lock=true # 启用线程 enable-threads=true # 设置自中断时间 harakiri=30 # 设置缓冲 post-buffering=4096 # 设置日志目录 daemonize=/opt/proj/script/uwsgi.log
启动项目:
usr/local/python3/bin/uwsgi --ini uwsgi.ini

访问网址: 192.168.2.108:8080

有时光有uwsgi还不够,uwsgi处理动态请求能力高,但对于静态请求(如static文件,css,js文件等)处理能力差,此时就要结合nginx一起使用
安装nginx
第一步:配置yum源
vim /etc/yum.repos.d/nginx.repo

wq保存推出
第二步:安装nginx
yum -y install nginx
安装完成后启动下检测是否安装成功
/etc/init.d/nginx start

访问192.168.2.108出现如下页面即代表nginx安装完成且可以正常启动

第三步:Django + Uwsgi + Nginx
首先创建配置文件,nginx的默认配置目录为/etc/nginx/conf.d
cd /etc/nginx/conf.d/

创建teacher.conf

配置内容如下:
server { # 这个server标识我要配置了
listen 80; # 我要监听那个端口
server_name 192.168.2.108 ; # 你访问的路径前面的url名称
access_log /var/log/nginx/access.log main; # Nginx日志配置
charset utf-8; # Nginx编码
gzip_types text/plain application/x-javascript text/css text/javascript application/x-httpd-php application/json text/json image/jpeg image/gif image/png application/octet-stream; # 支持压缩的类型
error_page 404 /404.html; # 错误页面
error_page 500 502 503 504 /50x.html; # 错误页面
# 指定项目路径uwsgi
location / { # 这个location就和咱们Django的url(r'^admin/', admin.site.urls),
include uwsgi_params; # 导入一个Nginx模块他是用来和uWSGI进行通讯的
uwsgi_connect_timeout 30; # 设置连接uWSGI超时时间
uwsgi_pass unix:/opt/proj/script/uwsgi.sock; # 指定uwsgi的sock文件所有动态请求就会直接丢给他
}
# 指定静态文件路径
location /static/ {
alias /opt/proj/teacher/static/;
index index.html index.htm;
}
}
重启nginx
/etc/init.d/nginx restart

访问: 192.168.2.108

相关命令:
# 启动Nginx通过Nginx访问 /etc/init.d/nginx start /etc/init.d/nginx stop # 这里有个命令configtest,Nginx配置是重启生效的,如果你修改完了,不知道对 不对又担心影响其他人可以使用它测试 /etc/init.d/nginx configtest # 如果是生产环境的话Nginx正在运行,就不要直接stop start 或者 restart 直接reload就行了 # 对线上影响最低 /etc/init.d/nginx reload
第二板块:
一, 实现本地链接远程服务器
购买服务器后通过Mac自带的终端通过ssh链接远程服务器
ssh username@192.168.100.100
其中,username是登录用户名,@后接ip地址,点击确定之后输入密码即连接到远程主机。
要查看当前有多少个处于登录状态的用户,可以使用who命令查看。
1, 首先进入root用户模式 sudo su - 2, 通过下面的命令链接 ssh -p 22 root@47.95.170.84 命令说明 ssh -p 22 服务器的端口号 root 服务器上的用户名 @ip 服务器的公网IP地址 ssh -p 22 root@47.95.170.84 输入命令后回车 之后输入yes 回车 之后输入服务器上对应的用户密码(root)

最后输入sudo su - 进入到服务器的根目录中进行相应的操作
退出L: control + d
二, 实现本地上传下载
使用scp命令实现上传下载
1 , 上传:
1.1 上传本地文件到服务器 scp /path/filename username@servername:/path ;
eg: scp /Users/mac/Desktop/test.txt root@123.207.170.40:/root/
1.2 上传目录到服务器 scp -r local_dir username@servername:remote_dir
把当前目录下的test目录上传到服务器的/root/ 目录
注:目标服务器要开启写入权限。
eg: scp -r test root@192.168.0.101:/root/
2, 下载:
2.1 从服务器上下载文件 scp username@servername:/path/filename /Users/mac/Desktop(本地目录)
就是将服务器上的/root/test.txt下载到本地的/Users/mac/Desktop目录下。注意两个地址之间有空格!
eg: scp root@123.207.170.40:/root/test.txt /Users/mac/Desktop
2.2 从服务器下载整个目录 scp -r username@servername:/root/(远程目录) /Users/mac/Desktop(本地目录)
eg: scp -r root@192.168.0.101:/root/ /Users/mac/Desktop/

浙公网安备 33010602011771号