第四百零二节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署,uwsgi安装和启动,nginx的安装与启动,uwsgi与nginx的配置文件+虚拟主机配置
第四百零二节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署,uwsgi安装和启动,nginx的安装与启动,uwsgi与nginx的配置文件+虚拟主机配置
软件版本
uwsgi-2.0.15
nginx-1.12.1
1.用Navicat Premium远程登录Linux系统数据库,创建网站需要的数据库
2.数据库创建好后,将开发环境的数据库传输到刚才创建的数据库
传输数据
如果在传输数据时,怎么都传输不了,老报错误,有可能是传输数据太大,要在软件设置一下,改一个变量,将参数调大
3.数据库数据传输好后,在Linux系统的opt目录创建Python虚拟环境,一般虚拟环境创建在opt目录不然会有权限问题
将开发环境里的整个Django项目,上传到Linux系统里准备好的python虚拟环境里的网站安装目录里,
在虚拟环境里创建一个网站目录,目录里包含两个文件夹,一个是Django项目,一个是创建来专门放配置文件的目录
上传好项目后,检查Django项目里的settings.py配置文件,配置数据库相关信息链接刚才导入的数据库,检查用户名密码是否正确,连接数据库的用户名,必须有操作当前网站数据库的权限,和当前用户可以任意ip访问数据库权限,详情见第三百九十九节的16小节说明
#MySQL数据库
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 配置数据库引擎名称
'NAME': 'jxiou2', # 数据库名称
'USER': 'test_user', # 数据库用户名
'PASSWORD': 'test_user', # 数据库密码
'HOST': '127.0.0.1', # 数据库链接地址
'PORT': '', # 数据库端口
}
}
修改后保存
4.测试Django项目项目是否能够运行
执行命令进入虚拟环境
[root@192 ~]# workon jxiou2
(jxiou) [root@192 ~]#
在虚拟环境里cd到Django根项目
[root@192 ~]# workon jxiou2
(jxiou) [root@192 ~]# cd /opt/xu_ni_huan_jing/jxiou2/jxiou/MxOnline 进入django根目录
(jxiou) [root@192 MxOnline]# dir 查看根目录下的文件
apps extra_apps manage.py media MxOnline __pycache__ static system templates
(jxiou) [root@192 MxOnline]#
执行命令,从manage.py启动Django项目
(jxiou) [root@192 MxOnline]# python manage.py runserver
Performing system checks... System check identified no issues (0 silenced). You have 1 unapplied migration(s). Your project may not work properly until you apply the migrations for app(s): reversion.
Run 'python manage.py migrate' to apply them. October 07, 2017 - 01:07:13
Django version 1.10, using settings 'MxOnline.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CONTROL-C.
可以看到项目已经启动,可以访问http://127.0.0.1:8000/
以上测试Django项目可以远行,这只是测试一下,正真的生产中不是从manage.py启动Django项目,而是用uwsgi模块来启动,所以以上只是为uwsgi做准备,至此在终端按ctrl+c键停止Django项目
【主题开始】
uwsgi+nginx+虚拟环境
uwsgi+nginx部署原理图
5.在虚拟环境安装uwsgi
uwsgi是Python写的一个模块,能启动Django项目,它的角色就是处理网站的动态请求
uWSGI的主要特点如下:
◆超快的性能。
◆低内存占用(实测为apache2的mod_wsgi的一半左右)。
◆多app管理。
◆详尽的日志功能(可以用来分析app性能和瓶颈)。
◆高度可定制(内存大小限制,服务一定次数后重启等)。
安装
(jxiou) [root@192 MxOnline]# pip install uwsgi
6.安装好uwsgi后,测试uwsgi启动Django项目
首先cd 进入到Django项目里,在此目录下执行命令
uwsgi --http 127.0.0.1:8000 --module MxOnline.wsgi(wsgi.py路径) --static-map=/static=static(静态文件路径)
(jxiou) [root@192 MxOnline]# uwsgi --http 127.0.0.1:8000 --module MxOnline.wsgi --static-map=/static=static
此时浏览器访问
http://127.0.0.1:8000/
此时可以看到uwsgi可以启动Django项目了,我们按ctrl+c关闭退出
uwsgi常用命令
ps -ef|grep -i uwsgi 查看uwsgi启动进程
pkill -9 nginx 杀掉uwsgi启动进程
uwsgi 启动uwsgi
7.使用配置文件启动uWSGI [ini]
在网站安装目录里与Django项目同级我们创建了一个pzhi文件夹,就是专门用来放配置文件的
在pzhi文件夹创建 网站名称_uwsgi.ini文件,来写uWSGI的配置文件
创建 jxiou_uwsgi.ini 文件
# uwsgi.ini
[uwsgi] # 指定Django项目的根目录
chdir = /opt/xu_ni_huan_jing/jxiou2/jxiou/MxOnline/ # 指定Django项目里的wsgi.py文件路径,上面已经指定了根目录,这里拼接根目录即可
module = MxOnline.wsgi # 启用主进程
master = true # 设置启动进程最大数
processes = 10 # 设置监听端口
socket = 127.0.0.1:8000 # 自动移除unix Socket和pid文件当服务停止的时候
vacuum = true # 设置python虚拟环境
virtualenv = /opt/xu_ni_huan_jing/jxiou2/ # 设置uwsgi日志保存路径,一般设置到当前配置文件所在目录
logto = /opt/xu_ni_huan_jing/jxiou2/jxiou/pzhi/uwsgi.log
创建好uWSGI的配置文件后,cd 进入到当前 jxiou_uwsgi.ini 配置文件目录,执行启动uwsgi命令
(jxiou) [root@192 pzhi]# uwsgi --ini jxiou_uwsgi.ini & 启动uwsgi配置文件
[uWSGI] getting INI configuration from jxiou_uwsgi.ini
(jxiou) [root@192 pzhi]# ps -ef|grep -i uwsgi 查看uwsgi启动进程
root 43159 1 1 03:50 ? 00:00:01 uwsgi --ini jxiou_uwsgi.ini
root 43164 43159 0 03:50 ? 00:00:00 uwsgi --ini jxiou_uwsgi.ini
root 43165 43159 0 03:50 ? 00:00:00 uwsgi --ini jxiou_uwsgi.ini
root 43166 43159 0 03:50 ? 00:00:00 uwsgi --ini jxiou_uwsgi.ini
root 43167 43159 0 03:50 ? 00:00:00 uwsgi --ini jxiou_uwsgi.ini
root 43168 43159 0 03:50 ? 00:00:00 uwsgi --ini jxiou_uwsgi.ini
root 43185 14898 0 03:51 pts/1 00:00:00 grep -i uwsgi
(jxiou) [root@192 pzhi]#
8.安装Nginx
在系统/etc/yum.repos.d/目录配置Nginx的安装源,
创建nginx.repo文件
vim /etc/yum.repos.d/nginx.repo
[nginx]
name=nginx repo
# 下面这行centos根据你自己的操作系统修改比如:OS/rehel
# 6是你Linux系统的版本,可以通过URL查看路径是否正确
baseurl=http://nginx.org/packages/centos/6/$basearch/
gpgcheck=0
enabled=1
可以访问一下http://nginx.org/packages/centos 安装源是否存在
9.配置好Nginx安装源后,执行命令安装Nginx
(jxiou) [root@192 pzhi]# yum -y install nginx
Nginx安装好后,Nginx的启动文件在 /usr/sbin/nginx 执行此文件即可启动Nginx
/etc/nginx/conf.d 这个目录为Nginx配置文件启动目录,当Nginx启动时会自动启动目录里的conf文件
注意:设置配置文件时,在系统创建文件将代码复制到文件里,不可在系统外导入配置文件
在网站安装目录里与Django项目同级我们创建了一个pzhi文件夹,就是专门用来放配置文件的
安装好nginx后在pzhi文件夹创建 网站名称_nginx.conf文件,来写nginxI的配置文件
创建 jxiou_nginx.conf 文件
# nginx配置文件
upstream django {
# 设置动态请求转发端口,要与uwsgi配置文件的socket监听端口一致
server 127.0.0.1:8000;
} server {
# 设置监听端口
listen 80; # 设置网站访问ip或者域名,域名要解析好
server_name 192.168.158.132 ; # 设置编码
charset utf-8; # 设置网站最大上传限制
client_max_body_size 75M; # 设置Django的media用户上传文件目录
location /media {
alias /opt/xu_ni_huan_jing/jxiou2/jxiou/MxOnline/media/;
} # 设置Django的static静态文件目录如js、css文件目录
location /static {
alias /opt/xu_ni_huan_jing/jxiou2/jxiou/MxOnline/static/;
} # 设置动态请求转发给uwsgi
location / {
# 动态请求时,执行upstream django的配置转发
uwsgi_pass django;
# 通过nginx启动目录 /etc/nginx/uwsgi_params 的uwsgi_params模块文件,与uwsgi交互
include uwsgi_params; # the uwsgi_params file you installed
} # 指定日志存放路径,一般指定到网站配置文件目录
access_log /opt/xu_ni_huan_jing/jxiou2/jxiou/pzhi/nginx.log main;
}
nginxI的配置文件写好后,将配置文件软连接到 /etc/nginx/conf.d 目录,也就是nginxI的启动目录
sudo ln -s /opt/xu_ni_huan_jing/jxiou2/jxiou/pzhi/jxiou_nginx.conf /etc/nginx/conf.d/
软连接创建好后,启动nginx
/usr/sbin/nginx 启动nginx
ps -ef|grep -i nginx 查看nginx启动进程
pkill -9 nginx 杀死nginx启动进程
补充内容防盗链配置
Nginx防盗链配置
有些时候,大家不想让别人调用自己的图片,一是因为个人版权的问题,再一点就是会增加服务器的负载、还会产生一些没必要的流量。 其实在Nginx里面,很容易就做到防盗链的,在nginx.conf文件加入一个localtion配置项。 下面请看配置: location ~ .*\.(jpg|jpeg|JPG|png|gif|icon)$ {
valid_referers blocked www.qixing318.com qixing318.com;
if ($invalid_referer) {
return 404;
}
}
gif|jpg|jpeg|….,这些是你想要屏蔽的文件类型,可以根据情况修改。 只需要把文中 www.qixing318.com qixing318.com 修改为你允许显示你网站图片的其他网站域名,注意中间用空格分开,而不是逗号。 这样直接返回的是404页面。也可以用http://domain.com/404.jpg,显示给盗链者看到的图片,注意不要放到自己的域名上,因为放盗链的作用,那样对方是看不到的,可以上传到一些支持外联的网络相册上。 当然了,也可以设置某个目录防盗链,只需把localtion匹配的改成一个目录就可以了,比如: location ~ ^/images/ {
valid_referers none blocked www.qixing318.com qixing318.com;
if ($invalid_referer) {
return 404;
}
#rewrite ^/ http://otherdomin.com/404.jpg;
}
启动nginx后访问nginx配置文件里设置的访问域名或者ip
当然此时网站可以启动了,但是后台和网站的一些样式和静态文件无法访问
所以,我们需要拉取所有静态文件到static目录
在django的setting文件中,添加下面一行内容:
STATIC_URL = '/static/' # 设置静态文件前缀名称
# 配置静态文件目录
#STATICFILES_DIRS = [
# os.path.join(BASE_DIR, 'static'), # 设置静态文件路径
#]
# 配置静态文件访问路径
STATIC_ROOT = os.path.join(BASE_DIR, 'static')
运行命令,拉取文件
cd 进入到网站项目根目录
python manage.py collectstatic
此时网站部署完成
注意:设置配置文件时,在系统创建文件将代码复制到文件里,不可在系统外导入配置文件
此时部署完成,网站配置文件夹里会有如下文件
日后操作管理
停止网站服务
首先进入虚拟环境
1.pkill -9 uwsgi 杀死uwsgi进程
2.ps -ef|grep -i uwsgi 查看进程情况
3.pkill -9 nginx 杀死nginx进程
4.ps -ef|grep -i nginx 查看进程情况
启动网站服务
首先进入虚拟环境
cd进入到uwsgi的配置文件目录
1.uwsgi -i jxiou_uwsgi.ini & 启动uwsgi
2.ps -ef|grep -i uwsgi 查看进程情况
3./usr/sbin/nginx 启动nginx
4.ps -ef|grep -i nginx 查看进程情况
最后别忘了关闭Django调试模式
就是在settings.py文件关闭调试模式,关闭后配置的404才能起作用,不至于大黄页
# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = False # 将调试模式关闭,关闭后访问页面出错不会显示错误(大黄页)
ALLOWED_HOSTS = ['*'] # 当关闭调试模式时,必须设置允许访问的ip,*代表所有以访问
第四百零二节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署,uwsgi安装和启动,nginx的安装与启动,uwsgi与nginx的配置文件+虚拟主机配置的更多相关文章
- 第三百九十八节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署CentOS6.5系统环境设置
第三百九十八节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署CentOS6.5系统环境设置 1.Linux安装配置 注意事项: 虚拟机网卡桥接模式 不要拨VPN 如果,网络怎么都 ...
- 第四百零一节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署virtualenv虚拟环境安装,与Python虚拟环境批量安装模块
第四百零一节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署virtualenv虚拟环境安装,与Python虚拟环境批量安装模块 virtualenv简介 1.安装virtuale ...
- 第三百九十九节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署CentOS6.5安装mysql5.6
第三百九十九节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署CentOS6.5安装mysql5.6 1.检测系统是否已经安装过mysql或其依赖,若已装过要先将其删除,否则第4步 ...
- 第四百节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署CentOS6.5安装python3.5.1
第四百节,Django+Xadmin打造上线标准的在线教育平台—生产环境部署CentOS6.5安装python3.5.1 1.检查系统是否安装了python [root@192 ~]# rpm -qa ...
- 第三百九十三节,Django+Xadmin打造上线标准的在线教育平台—Xadmin后台进阶开发配置
第三百九十三节,Django+Xadmin打造上线标准的在线教育平台—Xadmin后台进阶开发配置 设置后台某个字段的排序规则 在当前APP里的adminx.py文件里的数据表管理器里设置 order ...
- 第三百九十二节,Django+Xadmin打造上线标准的在线教育平台—sql注入攻击,xss攻击,csrf攻击
第三百九十二节,Django+Xadmin打造上线标准的在线教育平台—sql注入攻击,xss攻击,csrf攻击 sql注入攻击 也就是黑客通过表单提交的地方,在表单里输入了sql语句,就是通过SQL语 ...
- 第三百八十二节,Django+Xadmin打造上线标准的在线教育平台—xadmin管理员详情页面布局,导航图标设置
第三百八十二节,Django+Xadmin打造上线标准的在线教育平台—xadmin进阶 1.后台管理员详情页面布局 后台管理员详情页面,区块是可以拖动的,而且分为了很多个区块 这个页面的布局在xadm ...
- 第三百九十四节,Django+Xadmin打造上线标准的在线教育平台—Xadmin后台进阶开发配置2,以及目录结构说明
第三百九十四节,Django+Xadmin打造上线标准的在线教育平台—Xadmin后台进阶开发配置2,以及目录结构说明 设置后台列表页面可以直接修改字段内容 在当前APP里的adminx.py文件里的 ...
- 第三百八十四节,Django+Xadmin打造上线标准的在线教育平台—路由映射与静态文件配置以及会员注册
第三百八十四节,Django+Xadmin打造上线标准的在线教育平台—路由映射与静态文件配置以及会员注册 基于类的路由映射 from django.conf.urls import url, incl ...
随机推荐
- 【DWM1000】 code 解密6一TAG 状态机第一步
我们前面分析过,不论ANCHOR 还是TAG,前面变量的初始化基本都是一样的,只是状态机必须明确区分不同的设备类型.我们从开始看TAG.由于初始化TAG的 testAppState一样初始化为TA_I ...
- 以加密方式访问tomcat服务器
以加密方式(https)访问tomcat服务器,就要求对相应的端口配置加密连接器connector. 配置加密连接器的方法如下: 1.生成数字证书 利用jdk里的keytool生成证书,keytool ...
- 通过Redis、Memcache的 incr 原子操作防刷机制的使用差别
我的版本如下: Redis:3.2.100 Memcache:1.4.4 最近在处理服务器压力测试的时候,想到一个方案,在一定时间段内限制用户访问次数.具体的实现就是通过redis的院子操作incre ...
- MPU和CPU有什么区别?
MPU(或称MP,微处理器)和CPU(中央处理器)同为处理器,但范畴不同. 计算机(即电脑)分为巨型机,大型机,中型机,小型机和微型计算机5类.这5类计算机的运算核心统称为CPU,而MPU只是微型计算 ...
- linux 常用命令解压压缩
tar -zxvf filename.tar.gz // 解包 tar -xvf filename.tar // 解包 tar -zcvf filename.tar.gz target // 制作ta ...
- Expedition [POJ2431] [贪心]
题目大意: 有n个加油站,每个加油站的加油的油量有限,距离终点都有一个距离. 一个卡车的油箱无限,每走一个单元要消耗一单元的油,问卡车到达终点的最少加多少次油. 分析: 我们希望的是走到没油的时候就尽 ...
- 区间dp板子题:[noi1995]石子合并
非常经典的区间dp模板 对于每一个大于二的区间 我们显然都可以将它拆分成两个子序列 那么分别计算对于每个取最优值即可 #pragma GCC optimize("O2") #inc ...
- ssm框架出现的常见问题
1:自己写的代码测试的时候显示用户过期,需要释放拦截器,并配置权限允许 2:Servlet.service() for servlet [springmvc] in context with path ...
- yii2 配合bootstrap添加一个气泡
添加一个气泡 1.bootstrap 官网:http://getbootstrap.com/ 2.bootstrap 中文官网:http://v3.bootcss.com/ 添加气泡主要需要用到 bo ...
- 3ds max学习笔记(一)--选择物体
选择所有物体:编辑-->全选(快捷:ctrl+a),在其他空白地方点击则取消选择(或编辑-->选择不选)反选:选择一部分物体 --编辑--反选/ ctrl+i 快速反选加选物体:选择一部分 ...