Location配置项及LNMP架构

Location

使用Nginx Location可以控制访问网站的路径, 但一个server可以有多个location配置, 多个location的优先级该如何区分。

location匹配符号

匹配符 匹配规则 优先级
= 精确匹配 1
^~ 以某个字符串开头 2
~ 区分大小写的正则匹配 3
~* 不区分大小写的正则匹配 3
/ 通用匹配,任何请求都会匹配到 4
  1. server {
  2. listen 80;
  3. server_name _;
  4. location ~* /python {
  5. default_type text/html;
  6. return 200 "Location ~*";
  7. }
  8. location ~ /Python {
  9. default_type text/html;
  10. return 200 "Location ~";
  11. }
  12. location ^~ /python {
  13. default_type text/html;
  14. return 200 "Location ^~";
  15. }
  16. location = /python {
  17. default_type text/html;
  18. return 200 "Location =";
  19. }
  20. }

LNMP架构

LNMP是一套技术的组合,L=LinuxN=NginxM~=MySQLP~=Python

首先Nginx服务是不能处理动态请求,那么当用户发起动态请求时, Nginx又是如何进行处理的。

1. 静态请求:请求的内容是静态文件就是静态请求

1)静态文件:文件上传到服务器,永远不会改变的文件就是静态文件

2)html就是一个标准的静态文件

1. 动态请求:请求的内容是动态的就是动态请求

1)不是真实存在服务器上的内容,是通过数据库或者其他服务拼凑成的数据

当用户发起http请求,请求会被Nginx处理,如果是静态资源请求Nginx则直接返回,如果是动态请求Nginx则通过uwsgi协议转交给后端的Python程序处理

UWSGI

因为nginx不支持wsgi协议,无法直接调用py开发的webApp

  • 在nginx+uwsgi+Django的框架里,nginx代理+webServer,uwsgi是wsgiServer,Django是webApp
  • nginx接收用户请求,并判定哪些转发到uWsgi,uWsgi再去调用pyWebApp。

uwsgi服务部署

  1. 1、创建用户
  2. groupadd django -g 888
  3. useradd django -u 888 -g 888 -r -M -s /bin/sh
  4. 2、安装依赖软件
  5. yum install python3 libxml* python-devel gcc* pcre-devel openssl-devel python3-devel -y
  6. 3、安装Djangouwsgi
  7. pip3 install uwsgi django
  8. 4、创建项目
  9. cd /opt
  10. django-admin startproject linux
  11. cd linux
  12. django-admin startapp app01
  13. 4.1、修改配置文件
  14. vim /opt/linux/linux/settings.py
  15. ALLOWED_HOSTS = ['*'] # 所有网站都可以访问
  16. DATABASES = {} # 清空
  17. 4.2、测试 (测试上面的步骤)
  18. [root@web01 linux]# python3 manage.py runserver 0.0.0.0:8000
  19. 5、编辑项目配置文件
  20. [root@web01 ~]# vim /opt/linux/myweb_uwsgi.ini
  21. [uwsgi]
  22. # 端口号
  23. socket = :8000
  24. # 指定项目的目录
  25. chdir = /opt/linux
  26. # wsgi文件路径
  27. wsgi-file = linux/wsgi.py
  28. # 模块wsgi路径
  29. module = linux.wsgi
  30. # 是否开启master进程,用来监控worker进程
  31. master = true
  32. # 工作进程的最大数目,worker数量
  33. processes = 4
  34. # 结束后是否清理文件
  35. vacuum = true
  36. 6、启动uwsgi
  37. uwsgi -d --ini myweb_uwsgi.ini --uid 666
  38. -d:守护进程进行
  39. --ini:指定配置文件路径
  40. --uid:指定uid
  41. # 使用root启动会给一个警告!
  42. 7、编辑Nginx配置文件
  43. [root@web01 ~]# vim /etc/nginx/conf.d/python.conf
  44. server {
  45. listen 80;
  46. server_name py.test.com;
  47. location / {
  48. include uwsgi_params;
  49. uwsgi_pass 127.0.0.1:8000;
  50. uwsgi_read_timeout 2;
  51. uwsgi_param UWSGI_SCRIPT linux.wsgi;
  52. uwsgi_param UWSGI_CHDIR /opt/linux;
  53. index index.html index.htm;
  54. client_max_body_size 35m;
  55. }
  56. }
  57. 8、域名解析 windows
  58. 9、测试配置文件
  59. nginx -t
  60. 10、重启Nginx配置
  61. systemctl restart nginx

部署BBS项目

步骤

  1. 部署数据库
  1. [root@db01 ~]# yum install mariadb* -y
  1. 启动数据库
  1. [root@db01 ~]# systemctl start mariadb
  1. 远程连接MySQL数据
  1. MariaDB [(none)]> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
  2. Query OK, 0 rows affected (0.00 sec)
  3. MariaDB [(none)]> FLUSH PRIVILEGES;
  4. Query OK, 0 rows affected (0.00 sec)
  5. MariaDB [(none)]> CREATE DATABASE `bbs` DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;
  6. Query OK, 1 row affected (0.00 sec)
  1. pycharm连接数据库

测试连接成功


  1. 部署BBS
  1. # 上传代码
  2. [root@db01 ~]# unzip bbs.zip
  3. [root@db01 ~]# mv bbs /opt/
  4. # 数据库迁移之前清空/opt/bbs/app01/migrations目录下的py文件只留下双下init.py
  5. [root@web01 migrations]# pwd
  6. /opt/bbs/app01/migrations
  7. [root@web01 migrations]# rm -rf 00*
  8. [root@web01 migrations]# rm -rf __pycache__/
  9. # 切换路径
  10. [root@web01 migrations]# cd /opt/bbs/
  11. [root@web01 bbs]# pwd
  12. /opt/bbs
  13. # 修改Django版本
  14. [root@web01 bbs]# pip3 uninstall django
  15. [root@web01 bbs]# pip3 install django==1.11
  16. # 安装MySQL数据库插件
  17. [root@web01 bbs]# pip3 install pymysql
  18. # 修改数据连接
  19. [root@web01 bbs]# vim /opt/bbs/bbs/settings.py
  20. ALLOWED_HOSTS = ['*']
  21. DATABASES = {
  22. 'default': {
  23. 'ENGINE': 'django.db.backends.mysql',
  24. 'NAME': 'bbs',
  25. 'USER': 'root',
  26. 'PASSWORD': '123456',
  27. 'HOST': '172.16.1.61',
  28. 'PORT': 3306,
  29. 'CHARSET': 'utf8'
  30. }
  31. }
  32. # 修改Django版本和安装pymysql插件,修改配置文件,是为了满足创建数据库迁移文件准备
  33. # 创建数据库迁移文件
  34. [root@web01 bbs]# python3 manage.py makemigrations
  35. # 数据库迁移
  36. [root@web01 bbs]# python3 manage.py migrate
  37. # 数据库就有表了
  1. 配置UWSGI
  1. [root@web01 bbs]# vim /opt/bbs/myweb_uwsgi.ini
  2. [uwsgi]
  3. # 端口号
  4. socket = :8002
  5. # 指定项目的目录
  6. chdir = /opt/bbs
  7. # wsgi文件路径
  8. wsgi-file = bbs/wsgi.py
  9. # 模块wsgi路径
  10. module = bbs.wsgi
  11. # 是否开启master进程
  12. master = true
  13. # 工作进程的最大数目
  14. processes = 4
  15. # 结束后是否清理文件
  16. vacuum = true
  1. 配置Nginx
  1. # 配置nginx前,启动uwsgi
  2. [root@web01 bbs]# uwsgi -d --ini myweb_uwsgi.ini --uid 666
  3. # 配置Nginx
  4. [root@web01 bbs]# vim /etc/nginx/conf.d/bbs.conf
  5. server {
  6. listen 80;
  7. server_name bbs.test.com;
  8. location / {
  9. include uwsgi_params;
  10. uwsgi_pass 127.0.0.1:8002;
  11. uwsgi_read_timeout 2;
  12. uwsgi_param UWSGI_SCRIPT bbs.wsgi;
  13. uwsgi_param UWSGI_CHDIR /opt/bbs;
  14. index index.html index.htm;
  15. client_max_body_size 35m;
  16. }
  17. }
  1. 测试
  1. # 测试配置文件
  2. [root@web01 conf.d]# nginx -t
  3. nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
  4. nginx: configuration file /etc/nginx/nginx.conf test is successful
  1. 重启服务
  1. [root@web01 bbs]# systemctl restart nginx

10.windows hosts文件域名解析

  1. 测试访问bbs

bbs.test.com,成功了,可以admin管理登录


【写错请指正,搭建好有点丑~】

Location配置项及LNMP架构的更多相关文章

  1. 7、架构--location、LNMP架构、uwsgi部署、BBS项目部署

    笔记 1.晨考 1.Nginx中常用的模块 autoindex stub_status allow 和 deny basic limit_conn limit_req 2.配置步骤 1.创建连接池 2 ...

  2. LNMP 架构 与 部署 uwsgi 服务

    内容概要 nginx 配置文件中 location 匹配符号 LNMP 架构 uwsgi 服务部署 内容详细 一.location 使用 Nginx Location 可以控制访问网站的路径,但一个 ...

  3. linux中LNMP架构和location用法

    location 使用Nginx Location可以控制访问网站的路径,但一个server可以有多个location配置, 多个location的优先级该如何区分 location匹配符号 匹配符 ...

  4. nginx详解反向代理、负载均衡、LNMP架构上线动态网站(week4_day1_part1)-技术流ken

    nginx介绍 Nginx是俄罗斯人编写的十分轻量级的HTTP服务器,Nginx,它的发音为“engine X”,是一个高性能的HTTP和反向代理服务器,同时也是一个IMAP/POP3/SMTP 代理 ...

  5. lnmp架构实现动态php

    目录 LNMP动态网站php 1.PHP-FastCGI概述 PHP-FPM安装配置 配置PHP与数据库连接 配置PHP新增扩展模块 配置PHP-FPM主要配置 配置PHP-FPM错误日志 1.编译安 ...

  6. 部署企业LNMP架构搭建bbs

    部署企业LNMP架构 1===============部署Nginx 2===============安装及部署Mysql数据库 3===============安装PHP解析环境 4======== ...

  7. LNMP架构搭建

    目录 一:LNMP架构简介 1.Nginx与uwsgi 二:django框架+python 1.创建用户 2.安装依赖包 3.安装uwsgi和django 4.测试python 5.创建django项 ...

  8. 第20章 使用LNMP架构部署动态网站环境

    章节概述: 本章节将从Linux系统的软件安装方式讲起,带领读者分辨RPM软件包与源码安装的区别.并能够理解它们的优缺点. Nginx是一款相当优秀的用于部署动态网站的服务程序,Nginx具有不错的稳 ...

  9. lnmp架构(第一篇)

    lnmp 架构 第一篇 nginx 源码安装 nginx的安装包:nginx-1.12.0.tar.gz 建议安装前的修改: 在nginx的解压包中修改文件nginx-1.12.0/src/core/ ...

随机推荐

  1. MyBatis中sql实现时间查询的方法

    <if test="startTime != null and startTime !=''"> AND lTime >= #{startTime} </i ...

  2. OC-私有方法,构造方法,类的本质及启动过程

    总结 标号 主题 内容 一 OC的私有方法 私有变量/私有方法 二 @property 概念/基本使用/寻找方法的过程/查找顺序 三 @synthesize @synthesize概念/基本使用/注意 ...

  3. HTML样式 背景

    当浏览器读到一个样式表,就会按照这个格式表来对文档进行格式化.有以下三种方式来插入样式表: 1.外部样式表 当样式需要用到很多页面的时候,外部样式是理想的选择.使用外部样式表,就可以听过更改一个文件来 ...

  4. java实现链式线性表

    package ch9; public class LinkList <T>{ private class Node { //保存节点的数据 private T data; //指向下一个 ...

  5. Type of 'this' pointer in C++

    In C++, this pointer is passed as a hidden argument to all non-static member function calls. The typ ...

  6. 二、SpringBoot实现上传文件到fastDFS文件服务器

    上篇文章介绍了如何使用docker安装fastDFS文件服务器,这一篇就介绍整合springBoot实现文件上传到fastDFS文件服务器 1.pom.xml文件添加依赖 <!-- 连接fast ...

  7. SROP例题

    具体攻击原理可以参考安全客这篇文章:入口 刚学了一点,也是懵懵懂懂的,拿几道题来练练手. ciscn_2019_es_7 64位程序,只开启了NX保护. 相当于执行了read(0,buf,0x400) ...

  8. windows10 安装 Mysql8.0

    目录 1.Mysql8.0下载 2.配置环境变量 3.在安装目录下创建my.ini文件 4 初始化Mysql 5 安装至系统服务 6 更改密码 1.Mysql8.0下载 2.配置环境变量 将下载后文件 ...

  9. 小迪安全 Web安全 基础入门 - 第三天 - 抓包&封包&协议&APP&小程序&PC应用&WEB应用

    一.抓包工具 1.Fiddler.Fiddler是一个用于HTTP调试的代理服务器应用程序,能捕获HTTP和HTTPS流量,并将其记录下来供用户查看.它通过使用自签名证书实现中间人攻击来进行日志记录. ...

  10. Mysql 主从复制机制

    https://blog.csdn.net/girlgolden/article/details/89226528 MySQL异步复制及semi-sync半同步复制,它们都基于MySQL binlog ...