Nginx是什么,做什么的,有什么用?

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/Rm_and_Rf/article/details/100735361

Nginx是HTTP服务器(作为反向代理进行负载均衡的实现)

特性:
处理静态文件,索引文件以及自动索引;打开文件描述符缓冲.
无缓存的反向代理加速,简单的负载均衡和容错.
FastCGI,简单的负载均衡和容错.
模块化的结构。包括 gzipping, byte ranges, chunked responses,以及 SSI-filter 等 filter。如果由 FastCGI 或其它代理服务器处理单页中存在的多个 SSI,则这项处理可以并行运行,而不需要相互等待。
支持 SSL 和 TLSSNI

1.什么是代理:

代理就是一个代表,一个渠道;
列如:你去阿迪达斯专卖店买鞋,店铺去阿迪达斯厂商拿货,这个专卖店就是代理,阿迪达斯厂商是被代理角色,目标角色就是用户。

正向代理————隐藏用户信息
了解反向代理之前,首先了解下什么是正向代理。正向代理可以从生活方面和软件方面解释。平时你想要访问国外的一些网站的时候是没有办法访问的,这个时候你就会通过FQ的方式进行访问。FQ的方式是找到一个可以访问国外网站的代理服务器,我们将请求发送给代理服务器,代理服务器去访问国外的网站,然后将访问到的数据放回传递给我们。
上面这个就是正向代理,正向代理最大的特点就是隐藏用户的信息。客户端非常明确要访问的服务器地址,而服务器只知道请求来自哪个代理服务器,并不知道是哪个具体的客户端。
反向代理————隐藏服务器信息
明白了正向代理,我们再来看看反向代理。比如某宝网站,每天同时连接网站访问的人数已经爆表,单个服务器已经不能解决,这个时候就出现了一个耳熟能详的词:分布式部署;也就是通过部署多台服务器来解决人数限制问题,某宝的大部分功能也是直接使用Nginx进行反向代理实现的。并且通过封装Nginx和其他组件之后起了个高大上的名字:Tengine;感兴趣的可以看一下 http://tengine.taobao.org/
多台客户端同时给服务器发送请求,Nginx服务器接收到过后,按照一定的规则将请求分发给了后端的业务处理服务器进行处理。
上面这个就是反向代理。主要用于服务器集群分布式部署的情况下,隐藏了服务器的信息。请求来源的服务器是明确的,但是具体请求的是哪个服务器就不明确了,Nginx就是扮演了一个反向代理角色。

项目场景
通常情况下,正向代理与反向代理是同时存在的。

2.什么是负载均衡

客户端发送的、Nginx反向代理服务器接收到的请求数量,就是负载量
请求数量按照一定的规则进行分发到不同的服务器的过程,就是一种均衡规则
 所以,将服务器收到的请求规则分发的过程就叫负载均衡。

负载均衡在实际项目操作过程中,有硬件负载均衡和软件负载均衡两种,硬件负载均衡也称为硬负载,如F5负载均衡,相对造价昂贵成本较高,但是数据的稳定性安全性等等有非常好的保障,如中国移动中国联通这样的公司才会选择硬负载进行操作;更多的公司考虑到成本原因,会选择使用软件负载均衡,软件负载均衡是利用现有的技术结合主机硬件实现的一种消息队列分发机制

nginx支持的负载均衡调度算法方式如下:

weight轮询(默认):接收到的请求按照顺序逐一分配到不同的后端服务器,即使在使用过程中,某一台后端服务器宕机,nginx会自动将该服务器剔除出队列,请求受理情况不会受到任何影响。 这种方式下,可以给不同的后端服务器设置一个权重值(weight),用于调整不同的服务器上请求的分配率;权重数据越大,被分配到请求的几率越大;该权重值,主要是针对实际工作环境中不同的后端服务器硬件配置进行调整的。

ip_hash:每个请求按照发起客户端的ip的hash结果进行匹配,这样的算法下一个固定ip地址的客户端总会访问到同一个后端服务器,这也在一定程度上解决了集群部署环境下session共享的问题。

fair:智能调整调度算法,动态的根据后端服务器的请求处理到响应的时间进行均衡分配,响应时间短处理效率高的服务器分配到请求的概率高,响应时间长处理效率低的服务器分配到的请求少;结合了前两者的优点的一种调度算法。但是需要注意的是nginx默认不支持fair算法,如果要使用这种调度算法,请安装upstream_fair模块

url_hash:按照访问的url的hash结果分配请求,每个请求的url会指向后端固定的某个服务器,可以在nginx作为静态服务器的情况下提高缓存效率。同样要注意nginx默认不支持这种调度算法,要使用的话需要安装nginx的hash软件包

猜你喜欢

转载自blog.csdn.net/Rm_and_Rf/article/details/100735361