提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
Nginx
Nginx优点
- 速度快,并发量高
- 配置简单,扩展性强
- 高可靠性
- 热部署
- 成本低,使用BSD许可证
Nginx架构
Nginx 在启动后,会有一个 master 进程和多个 worker 进程。
master 进程主要用来管理 worker 进程,包含:接收来自外界的信号,向各 worker 进程发送信号,监控 worker 进程的运行状态,当 worker 进程退出后(异常情况下),会自动重新启动新的 worker 进程。
** worker 进程**之间是对等的,他们同等竞争来自客户端的请求,各进程互相之间独立,一个请求,只可能在一个 worker 进程中处理,一个 worker 进程
more
如下图:
工作流程
反向代理
反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个服务器。
正向代理
正向代理是一个位于客户端和原始服务器(origin server)之间的服务器。为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。
工作流程
- 用户通过域名发出访问Web服务器的请求,该域名被DNS服务器解析为反向代理服务器的IP地址;
- 反向代理服务器接受用户的请求;
- 反向代理服务器在本地缓存中查找请求的内容,找到后直接把内容发送给用户;
- 如果本地缓存里没有用户所请求的信息内容,反向代理服务器会代替用户向源服务器请求同样的信息内容,并把信息内容发给用户,如果信息内容是缓存的还会把它保存到缓存中。
Niginx模块
Nginx本身做的工作实际很少,当它接到一个HTTP请求时,它仅仅是通过查找配置文件将此次请求映射到一个location block,而此location中所配置的各个指令则会启动不同的模块去完成工作,因此模块可以看做Nginx真正的劳动工作者。
通常一个location中的指令会涉及一个handler模块和多个filter模块(当然,多个location可以复用同一个模块)。handler模块负责处理请求,完成响应内容的生成,而filter模块对响应内容进行处理
模块划分
结构上划分
- 核心模块:HTTP模块、EVENT模块和MAIL模块
- 基础模块:HTTP Access模块、HTTP FastCGI模块、HTTP Proxy模块和HTTP Rewrite模块,
- 第三方模块:HTTP Upstream Request Hash模块、Notice模块和HTTP Access Key模块。
功能上划分
- Core(核心模块):构建nginx基础服务、管理其他模块。
- Handlers(处理器模块):此类模块直接处理请求,并进行输出内容和修改headers信息等操作。
- Filters (过滤器模块):此类模块主要对其他处理器模块输出的内容进行修改操作,最后由Nginx输出。
- Proxies (代理类模块):此类模块是Nginx的HTTP Upstream之类的模块,这些模块主要与后端一些服务比如FastCGI等进行交互,实现服务代理和负载均衡等功能。
Nginx的核心模块主要负责建立nginx服务模型、管理网络层和应用层协议、以及启动针对特定应用的一系列候选模块。 其他模块负责分配给web服务器的实际工作:
- 当Nginx发送文件或者转发请求 到其他服务器,由Handlers(处理模块)或Proxies(代理类模块)提供服务;
- 当需要Nginx把输出压缩或者在服务端加一些东西,由Filters(过滤模块)提供服务。
模块处理
- 当服务器启动,每个handlers(处理模块)都有机会映射到配置文件中定义的特定位置(location)
返回形式
OK ERROR 或者放弃处理这个请求而让默认处理模块来处理(主要是用来处理一些静态文件,事实上如果是位置正确而真实的静态文件,默认的处理模块会抢先处理)。
- 如果handlers(处理模块)把请求反向代理到后端的服务器,就变成另外一类的模块:load-balancers(负载均衡模块)
负载均衡模块采用方法
轮转法,它处理请求就像纸牌游戏一样从头到尾分发; IP哈希法,在众多请求的情况下,它确保来自同一个IP的请求会分发到相同的后端服务器。
- 如果handlers(处理模块)没有产生错误,filters(过滤模块)将被调用
一个filters(过滤模块)被调用,完成其工作,然后调用下一个filters(过滤模块),直到最后一个filters(过滤模块)
特点: 每个filters(过滤模块)不会等上一个filters(过滤模块)全部完成; 它能把前一个过滤模块的输出作为其处理内容;有点像Unix中的流水线;
过滤模块能以buffer(缓冲区)为单位进行操作,这些buffer一般都是一页(4K)大小
可以总结出HTTP处理周期如下:
客户端发送HTTP请求 –> Nginx基于配置文件中的位置选择一个合适的处理模块 -> (如果有)负载均衡模块选择一台后端服务器 –> 处理模块进行处理并把输出缓冲放到第一个过滤模块上 –> 第一个过滤模块处理后输出给第二个过滤模块 –> 然后第二个过滤模块又到第三个 –> 依此类推 –> 最后把响应发给客户端。
流程图如下:
|