本期内容概要
- location
- lnmp架构
- 部署BBS项目
内容详细
1、location
使用Nginx Location可以控制访问网站的路径
但一个server可以有多个location配置
多个location是有优先级区分的 如下图:
匹配符 | 匹配规则 | 优先级 |
---|---|---|
= | 精确匹配 | 1 |
^~ | 以某个字符串开头 | 2 |
~ | 区分大小写的正则匹配 | 3(同级别自上而下匹配) |
~* | 不区分大小写的正则匹配 | 3(同级别自上而下匹配) |
/ | 通用匹配,任何请求都会匹配到 | 4 |
# 测试
先打包 /etc/nginx/conf.d目录下所有 .conf文件
[root@web01 conf.d]# vim test.conf
server {
listen 80;
server_name _; # '_' 匹配所有域名
location ~* /python { # 第三顺位(同级别自上而下匹配)
default_type text/html;
return 200 "Location ~*";
}
location ~ /Python { # 第三顺位(同级别自上而下匹配)
default_type text/html;
return 200 "Location ~";
}
location ^~ /python { # 其次匹配
default_type text/html;
return 200 "Location ^~";
}
location = /python { # 首先匹配
default_type text/html;
return 200 "Location =";
}
}
[root@web01 conf.d]# systemctl restart nginx
浏览器输入 IP/python 测试
192.168.15.7/python
见下图:
浏览器输入IP后加python 优先级最高先匹配 匹配到符合即停止
浏览器输入IP后加python 注释掉优先级最高匹配内容 匹配到符合第二顺位即停止
浏览器输入IP后加大写Python 注释掉优先级最高匹配内容和次优先级匹配内容 自伤而下匹配到符合匹配内容的即停止
其他注释掉再匹配
因为区分大小写 所有小写就会报错
2、lnmp架构
LNMP是一套技术的组合,L=Linux、N=Nginx、M=MySQL、P=Python
首先Nginx服务是不能处理动态请求,那么当用户发起动态请求时, Nginx又是如何进行处理的
1.静态请求:请求的内容是静态文件就是静态请求
01 静态文件:文件上传到服务器,永远不会改变的文件就是静态文件
02 html就是一个标准的静态文件
2.动态请求:请求的内容是动态的就是动态请求
01 不是真实存在服务器上的内容,是通过数据库或者其他服务拼凑成的数据
当用户发起http请求,请求会被Nginx处理,如果是静态资源请求Nginx则直接返回,如果是动态请求Nginx则通过uwsgi协议转交给后端的Python程序处理
2.1、uwsgi
因为nginx不支持wsgi协议,无法直接调用py开发的webApp
在nginx+uwsgi+Django的框架里,nginx代理+webServer,uWsgi是wsgiServer,Django是webApp
nginx接收用户请求,并判定哪些转发到uWsgi,uWsgi再去调用pyWebApp
主要作用就是:将nginx请求转发到python中去处理
2.2、uwsgi服务部署
1.创建用户
[root@web01 ~]# groupadd django -g 888
[root@web01 ~]# useradd django -u 888 -g 888 -r -M -s /bin/sh
2.安装依赖软件
[root@web01 ~]# yum install python3 libxml* python-devel gcc* pcre-devel openssl-devel python3-devel -y
3.安装Django和uwsgi
[root@web01 ~]# pip3 install django
[root@web01 ~]# pip3 install uwsgi
4.创建项目
[root@web01 ~]# cd /opt
[root@web01 opt]# django-admin startproject linux
[root@web01 opt]# cd linux
[root@web01 linux]# django-admin startapp app01
[root@web01 linux]# vim linux/settings.py
找到下面两处 并更改为以下:
ALLOWED_HOSTS = ['*']
DATABASES = {}
启动测试
[root@web01 linux]# python3 manage.py runserver 0.0.0.0:8000
- [django]正常启动了
5.编辑项目配置文件
[root@web01 linux]# pwd
/opt/linux
[root@web01 linux]# vim myweb_uwsgi.ini
[uwsgi]
# 端口号
socket = :8000
# 指定项目的目录
chdir = /opt/linux
# wsgi文件路径
wsgi-file = linux/wsgi.py
# 模块wsgi路径
module = linux.wsgi
# 是否开启master进程
master = true
# 工作进程的最大数目
processes = 4
# 结束后是否清理文件
vacuum = true
6.启动uwsgi
[root@web01 linux]# uwsgi -d --ini myweb_uwsgi.ini --uid 666
-d : 以守护进程方式运行(后台运行)
--ini : 指定配置文件路径
--uid : 指定uid
7.编辑Nginx配置文件
[root@web01 linux]# cd /etc/nginx/conf.d
[root@web01 conf.d]# vim py.conf
server {
listen 80;
server_name py.test.com;
location / {
include uwsgi_params;
uwsgi_pass 127.0.0.1:8000;
uwsgi_read_timeout 2;
uwsgi_param UWSGI_SCRIPT linux.wsgi;
uwsgi_param UWSGI_CHDIR /opt/linux;
index index.html index.htm;
client_max_body_size 35m;
}
}
[root@web01 conf.d]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
8.重启nginx配置
[root@web01 conf.d]# systemctl restart nginx
将域名:py.test.com 在Windows中解析
C:\Windows\System32\drivers\etc
192.168.15.7 game.marie.com game.chess.com py.test.com
3、部署BBS项目
1.部署数据库
先开启数据库服务器 db01
[root@db01 ~]# yum install mariadb* -y
2.启动数据库
[root@db01 ~]# systemctl start mariadb
3.远程连接MySQL数据
[root@db01 ~]# mysql
MariaDB [(none)]> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION; # 第一步
Query OK, 0 rows affected (0.00 sec) # 自动回显内容
MariaDB [(none)]> FLUSH PRIVILEGES; # 第二步
Query OK, 0 rows affected (0.00 sec) # 自动回显内容
MariaDB [(none)]> CREATE DATABASE `bbs` DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci; # 第三步
Query OK, 1 row affected (0.00 sec) # 自动回显内容
4.部署BBS
01 上传代码
[root@web01 ~]# unzip bbs.zip
[root@web01 ~]# mv bbs /opt/
02 数据库迁移
[root@web01 ~]# cd /opt/bbs/app01/migrations
[root@web01 migrations]# rm -rf 00*
[root@web01 migrations]# rm -rf __pycache__/
[root@web01 migrations]# cd /opt/bbs/
修改Django版本
[root@web01 bbs]# pip3 uninstall django
[root@web01 bbs]# pip3 install django==1.11
安装MySQL数据库插件
[root@web01 bbs]# pip3 install pymysql
修改数据连接
[root@web01 bbs]# vim bbs/settings.py
ALLOWED_HOSTS = ['*']
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'bbs',
'USER': 'root',
'PASSWORD': '123456',
'HOST': '192.168.15.61',
'PORT': 3306,
'CHARSET': 'utf8'
}
}
创建数据库迁移文件
[root@web01 bbs]# python3 manage.py makemigrations
数据库迁移
[root@web01 bbs]# python3 manage.py migrate
03 配置UWSGI
[root@web01 bbs]# vim /opt/bbs/myweb_uwsgi.ini
[uwsgi]
# 端口号
socket = :8002
# 指定项目的目录
chdir = /opt/bbs
# wsgi文件路径
wsgi-file = bbs/wsgi.py
# 模块wsgi路径
module = bbs.wsgi
# 是否开启master进程
master = true
# 工作进程的最大数目
processes = 4
# 结束后是否清理文件
vacuum = true
[root@web01 bbs]# uwsgi -d --ini myweb_uwsgi.ini --uid 666
04 配置Nginx
[root@web01 conf.d]# vim bbs.conf
server {
listen 80;
server_name bbs.test.com;
location / {
include uwsgi_params;
uwsgi_pass 127.0.0.1:8002;
uwsgi_read_timeout 2;
uwsgi_param UWSGI_SCRIPT bbs.wsgi;
uwsgi_param UWSGI_CHDIR /opt/bbs;
index index.html index.htm;
client_max_body_size 35m;
}
}
[root@web01 conf.d]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@web01 conf.d]# systemctl restart nginx
05 测试访问BBS
将域名:py.test.com 在Windows中解析
C:\Windows\System32\drivers\etc
192.168.15.7 game.marie.com game.chess.com py.test.com bbs.test.com