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 ,完美路径!

Nginx的静态代理的更多相关文章

  1. 用nginx的反向代理机制解决前端跨域问题在nginx上部署web静态页面

    用nginx的反向代理机制解决前端跨域问题在nginx上部署web静态页面 1.什么是跨域以及产生原因 跨域是指a页面想获取b页面资源,如果a.b页面的协议.域名.端口.子域名不同,或是a页面为ip地 ...

  2. nginx的应用【静态代理、动静分离】

    Nginx主要应用: 静态web服务器 负载均衡 静态代理虚拟主机 静态代理 :把所有静态资源的访问改为访问nginx,而不是访问tomcat,因为nginx更擅长于静态资源的处理,性能更好,效率更高 ...

  3. Windos环境用Nginx配置反向代理和负载均衡

    Windos环境用Nginx配置反向代理和负载均衡 引言:在前后端分离架构下,难免会遇到跨域问题.目前的解决方案大致有JSONP,反向代理,CORS这三种方式.JSONP兼容性良好,最大的缺点是只支持 ...

  4. 在ubuntu上面配置nginx实现反向代理和负载均衡

    上一篇文章(http://www.cnblogs.com/chenxizhang/p/4684260.html),我做了一个实验,就是利用Visual Studio,基于Nancy框架,开发了一个自托 ...

  5. Nginx实现静态资源的缓存

    1.1   需求 1.对静态文件进行缓存:html,js,css,png,gif,jpg,jpeg,bmp,swf. 2.对符合url规则的请求进行缓存. 3.针对某个url进行清除缓存. 1.1   ...

  6. 安装nginx 做反向代理

    nginx反向代理配置实例(前nginx+后apache)Nginx ("engine x") 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP ...

  7. Nginx +iis反向代理

    一:简介      Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行.由俄罗斯的程序设计师Igor Sysoev所 ...

  8. Nginx + Apache 反向代理

    反向代理负载均衡 使用代理服务器可以将请求转发给内部的Web服务器,使用这种加速模式显然可以提升静态网页的访问速度.因此也可以考虑使用这种技术,让代理服务器将请求均匀转发给多台内部Web服务器之一上, ...

  9. nginx的反向代理功能和缓存功能

    html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...

随机推荐

  1. wordpress 添加 显示磁盘剩余空间百分比的插件

    在 wp-content/plugins 文件夹下 我取的文件名是: folder-sizes-dashboard-widget.php 在仪表盘 可以看到 Folder Sizes 标题的Box & ...

  2. app混合开发 fastlick.js 在ios上 input标签点击 不灵敏 处理

    ios11 上有这个问题 而老版本的ios没有 会出现这个的原因是使用fastclick.js点击后input没有获取焦点,所以只需要在fasyclick的源码的这个位置 可以直接在源码内搜索关键字找 ...

  3. Java——异常的基本概念

    1.异常的基本概念 1.1什么是异常 在使用计算机语言进行项目开发的过程中,即使程序员把代码写得尽善尽美,在系统的运行过程中仍然会遇到一些问题,因为很多问题不是靠代码能够避免的,比如:客户输入数据的格 ...

  4. thinkphp 图形处理

    使用Think\Image类进行图像处理功能,支持Gd库和Imagick库,包括对GIf图像处理的支持. 实例化类库 $image = new \Think\Image(); 默认使用GD库进行图像操 ...

  5. 质数密度+思维——cf1174D

    /* 构造 n个点的无向图,无重边自环 边数e也是质数 点的度数也是质数 */ #include<bits/stdc++.h> #include<vector> using n ...

  6. 电脑U盘启动制作

    1.用老毛桃.大白菜制作U盘驱动时,不要直接默认一键制作.不然安装的系统会植入第三方的软件的.一定要进行个性化设置中取消赞助商.

  7. Java-Class-E:org.springframework.http.HttpStatus

    ylbtech-Java-Class-E:org.springframework.http.HttpStatus 1.返回顶部   2.返回顶部   3.返回顶部   4.返回顶部 1. /* * C ...

  8. ArcGIS version not specified.

    问题 在调用arcgis10 的ISurface用来取指定航线的地形时,这段代码在加载.dem时总是出错. 报: Fail to open raster dataset 解决方法: 在窗体中加载Map ...

  9. 18、Page Object 设计模式

    Page Object 设计模式的优点如下: 减少代码的重复. 提高测试用例的可读性. 提高测试用例的可维护性, 特别是针对 UI 频繁变化的项目. 当你针对网页编写测试时,你需要引用该网页中的元素, ...

  10. python3 递归函数return返回None

    今天写了一个函数,执行之后打印出来的结果是None,不明白,之后百度了一下,这里记一下过程,免得之后再踩坑 #!/usr/bin/python3# -*- coding:utf-8 -*- def b ...