简单介绍

. 高性能的web服务器,开源免费;

. 一般用于做静态服务,负载均衡;
静态服务:什么叫静态服务,做一个CDN,放图片文件,CSS文件,等静态文件 ,也就是服务端不需要进行解析就可以直接返回的静态文件,都可以利用Nginx做一个高性能的静态服务;

负载均衡:比如说我们有一个server的集群,集群的话比如说有5台机器,其中有一台主机器,就是流量都往它这边跑,剩下的几台怎么去分摊流量以致于我们整个集群的负载能达到最高,这也可以通过Nginx去做配置。因为Nginx内部有一个模块就可以进行一个负载均衡的配置,它能做一个入口,比如说流量来了之后它可以分配到不同的机器上去,而且能平均流量。

反向代理:
SharedScreenshot.jpg
为什么叫反向代理呢 — 所谓反向代理简单的意思就是它对客户端一个不可逆的代理,就叫反向代理。和反向代理相反的是正向代理,例如公司的内网,我们在家里是访问不了的,需要在本机上安装一个代理工具然后才能去访问,这属于的是一个正向代理,因为这是客户端浏览器能控制的代理。server端全部涵盖了,客户端控制不了,相当于一个黑盒,就是一个反向代理。
就是说上面遇到’’/‘请求就代理到html,遇到’/api’就代理到nodejs,这样的话Nginx就会做一个同一个入口。

下面就是某博客大神的讲解,图文啥的都有牛逼![https://blog.csdn.net/tsummerb/article/details/79248015**](https://blog.csdn.net/tsummerb/article/details/79248015)
**

1. 反向代理

关于代理
说到代理,首先我们要明确一个概念,所谓代理就是一个代表、一个渠道;
此时就设计到两个角色,一个是被代理角色,一个是目标角色,被代理角色通过这个代理访问目标角色完成一些任务的过程称为代理操作过程;如同生活中的专卖店~客人到adidas专卖店买了一双鞋,这个专卖店就是代理,被代理角色就是adidas厂家,目标角色就是用户

Nginx的使用(一)-- 基本介绍 - 图2
正向代理
说反向代理之前,我们先看看正向代理,正向代理也是大家最常接触的到的代理模式,我们会从两个方面来说关于正向代理的处理模式,分别从软件方面和生活方面来解释一下什么叫正向代理
在如今的网络环境下,我们如果由于技术需要要去访问国外的某些网站,此时你会发现位于国外的某网站我们通过浏览器是没有办法访问的,此时大家可能都会用一个操作FQ进行访问,FQ的方式主要是找到一个可以访问国外网站的代理服务器,我们将请求发送给代理服务器,代理服务器去访问国外的网站,然后将访问到的数据传递给我们!
上述这样的代理模式称为正向代理,正向代理最大的特点是客户端非常明确要访问的服务器地址;服务器只清楚请求来自哪个代理服务器,而不清楚来自哪个具体的客户端;正向代理模式屏蔽或者隐藏了真实客户端信息。

Nginx的使用(一)-- 基本介绍 - 图3
反向代理
明白了什么是正向代理,我们继续看关于反向代理的处理方式,举例如我大天朝的某宝网站,每天同时连接到网站的访问人数已经爆表,单个服务器远远不能满足人民日益增长的购买欲望了,此时就出现了一个大家耳熟能详的名词:分布式部署;也就是通过部署多台服务器来解决访问人数限制的问题;某宝网站中大部分功能也是直接使用nginx进行反向代理实现的,并且通过封装nginx和其他的组件之后起了个高大上的名字:Tengine,有兴趣的童鞋可以访问Tengine的官网查看具体的信息:http://tengine.taobao.org/
那么反向代理具体是通过什么样的方式实现的分布式的集群操作呢,我们先看一个示意图:
Nginx的使用(一)-- 基本介绍 - 图4

通过上述的图解大家就可以看清楚了,多个客户端给服务器发送的请求,nginx服务器接收到之后,按照一定的规则分发给了后端的业务处理服务器进行处理了。此时~请求的来源也就是客户端是明确的,但是请求具体由哪台服务器处理的并不明确了,nginx扮演的就是一个反向代理角色
反向代理,主要用于服务器集群分布式部署的情况下,反向代理隐藏了服务器的信息!
项目场景
通常情况下,我们在实际项目操作时,正向代理和反向代理很有可能会存在在一个应用场景中,正向代理代理客户端的请求去访问目标服务器,目标服务器是一个反向单利服务器,反向代理了多台真实的业务处理服务器。具体的拓扑图如下:
Nginx的使用(一)-- 基本介绍 - 图5

2. 负载均衡

我们已经明确了所谓代理服务器的概念,那么接下来,nginx扮演了反向代理服务器的角色,它是以依据什么样的规则进行请求分发的呢?不用的项目应用场景,分发的规则是否可以控制呢?
这里提到的客户端发送的、nginx反向代理服务器接收到的请求数量,就是我们说的负载量
请求数量按照一定的规则进行分发到不同的服务器处理的规则,就是一种均衡规则
所以~将服务器接收到的请求按照规则分发的过程,称为负载均衡。
负载均衡在实际项目操作过程中,有硬件负载均衡和软件负载均衡两种,硬件负载均衡也称为硬负载,如F5负载均衡,相对造价昂贵成本较高,但是数据的稳定性安全性等等有非常好的保障,如中国移动中国联通这样的公司才会选择硬负载进行操作;更多的公司考虑到成本原因,会选择使用软件负载均衡,软件负载均衡是利用现有的技术结合主机硬件实现的一种消息队列分发机制
Nginx的使用(一)-- 基本介绍 - 图6

**