Nginx实现原理及架构解析.docx
《Nginx实现原理及架构解析.docx》由会员分享,可在线阅读,更多相关《Nginx实现原理及架构解析.docx(17页珍藏版)》请在优知文库上搜索。
1、1.NginX是什么NginXengineX建一个开源的轻量级的HTTP服务器部够提供高性能的HTTP和反向代理服务.与传统的Apache服务器相比,在性能上Nginx占用系统资源更小、支持高并发,访问效率更高;在功能上,Nginx不仅作为Web服务软件,还适用于反向代理、负载均衡等场品;在安装配署上,Nginx更为简单、灵活.Nginx因为并发性能和资源占用上的优势,已经广泛用于大中型互联网企业.1.1 Nginx特点Nginx具有以下特点:支持高并发:NginX是专门为性能优化而开发的,采用内核Poll模型,单机能够支持几万以上的并发连接低资源消耗:Nginx采取了分阶段资源分配技术,使得
2、CPU与内存的占用率非常低.一般1万个非活跃的HTTPKeep-Alive连接在Nginx中仅消耗几MB内存高拓展性:设计模具扩展性,由多个不同功能、不同层次、不同类型且藕合度极低的模块组成高可用性:Nginx支持热部署,其中的master管理进程与worker工作进程的分阁设计;启动速度特别迅速,因此可以在不间断服务的情况下,对软件版本或者配置迸行升级,即使运行数月也无需重新启动,几乎可以做到7x24小时不间断地运行丰富的使用场景:可以作为Web服务端、HTTP反向代理、负载均衡和前端缓存服务等场景使用开源协议:使用BSD许可协议,免赛使用,且可修改源码1.2 NginX使用场景1.2.1
3、反向代理代理服务器一般指代局域网内部的机器通过代理服务发送请求到互联网上的服务器,代理服务器一股作用于客户端.代理服务器是介于客户端和Web服务器之间的服务器,客户端首先与代理服务器创建连接,然后根据代理服务器所使用的代理协议,请求对目标服务器创建连接、或则获得目标服务器的指定资源。正向代理:为了从原始服务器取的内容,客户端向代理发送一个请求并指定目标(Web服务器),然后代理向Web服务器转交请求并将获得的内容返回给客户端,客户端必须要进行一些特别的设置才能使用正向代理。像VPN就是正向代理,一般在浏览器中配置代理服务器的相关信息.OO正向代理中代理的对象是客户端,代理服务器和客户端属于同一
4、个1.AN,对服务器端来说是透明的.O反向代理:客户端发送请求到代理服务器,由代理服务器转发给相应的Web服务器进行处理,最终返回结果给客户端.像Nginx就是反向代理服务器软件,对客户端寒露的其实是一个VIP,不是真实的Web服务器的IP.反向代理的是对象是Web服务器端,代理服务器和Web服务端属于同一个1.AN,对客户端来说是透明的.o使用反向代理的好处是客户端不需要任何配置就可以访问,对外疑露的是代理服务器的地址隐嬴了真实服务器的地址,客户端只需要把请求发送给代理服务器,由代理服务器去选择后端的Web服务器,获取到数据后再返回给客户端.1.2.2 负载均衡负载均衡建立在现有网络结构之上
5、,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、熠加吞吐量、加强网络数据处理能力、提高网络的樊活性和可用性.负载均衡(1.oadBalance)其意思就是分施到多个操作单元上迸行执行,例如Web服务器、FTP服务器、企业关挺应用服务器和其它关耀任务服务器等,从而共同完成工作任务.简而言之,单个Web应用服务器不能承受日益增长的并发员请求,因此需要不断扩展Web服务器来支撑高并发请求,根据不同的负载均衡策略将请求分配到各个服务器上.NginX支持三种不同的负载均衡策略轮询:每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉能够被自动剔除.轮询算法适合服务器配背相当
6、,无状态且短平快的服务使用.weight权重:指定轮询的几率,weight和后端的访问比例成比例,weight权至越高比例越大.通常用于后端服务器配音不均的情况.ip-hash:上面两种算法存在一个问透是就是无法做到会话保持,当用户登录到服务器上后,第二次请求的时候会被定位到服务器集群中的某一个,那么已经登录到某个服务器上的用户会圭新定位到另一台,之前的登录信息会丢失.ipjash算法可以解决这个问题,当用户再次访问请求时,会通过hash算法自动定位到已经登录的服务器上,这样每个客户端可以固定在某个Web服务器上,解决客户端session的问期.1.2.3 动静分离动静分离技术是让动态网站里的
7、动态网页根据一定规则把不变的资源和经常变的费源区分开来,将静态文件放在一个单独的Web服务器上,加快解析速度,降低原来单个服务器的压力。在Nginx的配置中,在SerVer段中加入带正则匹配的location来指定匹配项针对PHP的动静分离:静态页面交给Nginx处理,动态页面交给PHP-FPM模块或Apache处理。1.3 NginX功能模块说明Nginx由内核和模块组成,其中内核在设计上非常简洁,完成的工作非常简单,仅仅通过查找配置文件将客户端请求映射到一个locationblock,而在这个I。Cation中所配置的每个指令将会启动不同的模块去完成相应的工作。1.3.1 Nginx模块分
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Nginx 实现 原理 架构 解析
