• Nginx的静态代理


    Nginx的静态代理

    Nginx的web请求的处理机制

    • Nginx结合多进程和异步机制对外提供服务,异步机制使用的是异步非阻塞机制,即AIO,Nginx的master进程会生成多个worker进程,master进程负责管理这些worker进程的生命周期、接受外部命令、解析perl脚本等工作,而worker进程则用于接受和处理用户的客户端请求;

    • 每个worker进程都是使用异步非阻塞方式处理多个客户端请求,当某个worker接到客户端的请求之后,其会调用IO进行处理,如果不能立即得到结果,worker机会去处理其他请求,当这个IO返回结果时,会通知worker进程,worker进程接收到通知后,就会挂起当前正在执行的事务,拿IO返回结果去响应给客户端,worker进程采用的是epoll事件驱动模型与IO进行通信,epoll模型底层采用的是"回调callback"替代了轮询,使用效率要高于select模型

    使用到的命令

    • ngxin -h : 查看命令选项

    • ngxin -c file : 启动命令

    • ngxin -s stop/quite : 停止命令

    • nginx -s reload : 平滑重启

    • nginx -tq : 检测配置文件是否出错,常用

    请求定位(开胃小菜)

    这个其实不算核心功能,但作为一个引入为后面的讲解做一个铺垫还是很有必要的,在我们安装玩Nginx后,我们对其进行访问,就会得到一个"Welcome to nginx"的页面,为什么我们访问80端口就能访问到这个页面呢?其中是不是指定了默认的显示的页面,就想index.html那样?

      

    首先我们找到安装目录下的conf文件夹下的nginx.conf配置文件:cat /usr/local/nginx/conf/nginx.conf

    然后我们就可以看到以下配置:

    • listen:代表监听的端口

    • location :个人理解为一个拦截规则并对拦截到的请求做中括号里面的逻辑

    • location后跟的是 "/",表示拦截所有,也对资源定位有一个约束,后面有详细介绍

    • root:指定一个资源定位目录为 :html目录,也可以指定绝对路径

    • index:指定一个资源文件为:index.tml,后面还可以跟多个,第一个访问不了就访问第二个

    • 总结:拦截80端口的所有请求,指定路径为:根目录下的html目录下的index.html资源

    • 总结:拦截80端口的所有请求,指定路径为:根目录下的html目录下的index.html资源

    下面我们来看看这个index.html是个什么页面

      

    可以看到这个html,就是我们刚安装完毕后,测试访问时的那个页面,为什么要说这个东西呢?因为后面的知识点都要设计到nginx.conf中的拦截规则已经相应逻辑操作,在这里先打个铺垫。

    静态代理

    • 经过前面的开胃小菜,我相信大家心里都对Nginx的大概逻辑流程有一点点的B数了

    • 动态代理:将所有的静态资源,比如【html、css、js、jpg、...】等资源存放到Nginx服务器,而不存放在应用服务器Tomcat中,当客户端对这些静态资源进行访问的时候,就可以不用去麻烦Tomcat了,我们Nginx直接将其响应给客户端,这样就大大降低了应用服务器Tomcat的负载压力,

    • 同时Nginx对于静态资源的处理相较于Tomcat,所有在很多场景里面,Ningx都是作为静态代理服务器,专门处理静态资源的请求响应;

    下面我们动手操刀,一起来看看着静态代理

    • 首先我们配置我们的Nginx的配置文件,增添我们自己的拦截规则:

    • 这里值得注意的是,每个配置后面都是以";"结尾,不然识别不出来

    • 我配置的这个拦截规则是什么意思呢?拦截 “ip:port/bb/cc” 的请求,

    • 对拦截到的请求响应资源 : /opt/aa/bb/cc/default.html页面

    • 级联创建自定义资源存放目录 : mkdir /opt/aa/bb/cc -p

    • 进入cc目录,创建自定义资源default.html : echo "This is default page" > /opt/aa/bb/cc/default.html

    • 然后我们平滑重动Nginx : ngxin -s reload,然后开始访问测试:

    location后跟的拦截规则是支持正则表达式的,下面我们来看看:

    首先修改nginx.conf配置文件如下:

      

    • 正则表达式的运用在Nginx中都是以 ~ 打头 以$收尾 : ~ ...$

    • .:表示任意字符

    • *:0个或多个

    • :转义,后面跟"."表示真正的"."

    • (jpg|png|css|js|html) :限定请求的资源类型为其中之一;

    修改完配置文件,记得检测一下配置文件是否语法通过 : nginx -tq

      

    发现有误,就要及时的改正:大括号和正则表达式之间有个空格,需要打出来

    我们已经把拦截规则设立好了,我们的静态资源也得到位才能看效果,上传图片到 /opt/statics/images/

      

    然后我们想一下,根据前面教的经验,这些图片根据我们的拦截规则,我们该发起什么样的URL才能访问?

    http://92.168.159.169:80 / ?? / ?? ,我们知道我的资源访问规则是 Root指定的目录+拦截的目录

    所以路径为? http://92.168.159.169:80 / images/6.jpg ,先测试一下行的同否

      

    完美! 你,想通了吗?

    首先我们的拦截规则是零个或多个任意字符 " ip:port//images/6" 符合我们的拦截规则

    然后".jpg"也符合我们的请求资源类型约束规则

    其次就是资源定位问题:

    • root属性所指定的目录 :/opt/statics

    • 此条请求的拦截规则中路径:images/6.jsp

    • 两个相并 : /opt/statics/images/6.jgp ,完美路径!

  • 相关阅读:
    flutter,跟着官网一步一步创建第一个flutter应用
    meta标签的用处详解
    js array 对象
    javascript异步编程,promise概念
    jquery常用
    《java编程思想》:异常丢失
    Nginx均衡负载配置
    Maven将jar包安装到本地仓库
    《java编程思想》读后笔记:二,吸血鬼数字
    基于jQuery Ajax实现无刷新文件上传
  • 原文地址:https://www.cnblogs.com/msi-chen/p/11130852.html
Copyright © 2020-2023  润新知