Nginx结合多进程和异步机制对外提供服务,异步机制使用的是异步非阻塞机制,即AIO,Nginx的master进程会生成多个worker进程,master进程负责管理这些worker进程的生命周期、接受外部命令、解析perl脚本等工做,而worker进程则用于接受和处理用户的客户端请求;css
每一个worker进程都是使用异步非阻塞方式处理多个客户端请求,当某个worker接到客户端的请求以后,其会调用IO进行处理,若是不能当即获得结果,worker机会去处理其余请求,当这个IO返回结果时,会通知worker进程,worker进程接收到通知后,就会挂起当前正在执行的事务,拿IO返回结果去响应给客户端,worker进程采用的是epoll事件驱动模型与IO进行通讯,epoll模型底层采用的是"回调callback"替代了轮询,使用效率要高于select模型html
ngxin -h : 查看命令选项nginx
ngxin -c file : 启动命令web
ngxin -s stop/quite : 中止命令正则表达式
nginx -s reload : 平滑重启服务器
nginx -tq : 检测配置文件是否出错,经常使用异步
这个其实不算核心功能,但做为一个引入为后面的讲解作一个铺垫仍是颇有必要的,在咱们安装玩Nginx后,咱们对其进行访问,就会获得一个"Welcome to nginx"的页面,为何咱们访问80端口就能访问到这个页面呢?其中是否是指定了默认的显示的页面,就想index.html那样?jsp
首先咱们找到安装目录下的conf文件夹下的nginx.conf配置文件:cat /usr/local/nginx/conf/nginx.conf测试
ui
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