Nginx介绍

首先我们先来了解一下nginx到底是什么东西,nginx其实是一个自由的开源的高性能的web服务器和反向代理服务器。

一.代理

代理,名如其意一个代表,代表你去干什么事情,这样又出来了两个角色,被代理人,和目标角色,我们来举一个生活中的例子:我们去一家手机专卖店去买了一部手机,那么这个手机专卖店就是手机厂商的代理,被代理人就是手机厂商,目标人物就是我们。

1.正向代理

代理又可以分为正向代理,和反向代理,我们先来介绍一下正向代理。在如今网络环境下我们有时候去访问,国外的网站,但此时我们就会发现我们是没办法访问国外的网站,而这个时候,我们就需要找一个能够访问国外网站的代理,我们把我们要访问的网站,发给他,他在将我们的请求,转发给我们的目标网站,让后在将获取下来的数据反馈给我们,这就是正向代理,这个模式,我们客户是非常清楚我们要访问的网站的服务器地址的,但是服务器,他并不知道真正的客户端来自哪里,他只知道请求来自那个代理服务商,正向代理屏蔽或隐藏了客服端的信息。

2.反向代理

我们已经了解了,正向代理我们再来了解一下反向代理,反向代理,其实我们的目标服务器就是代理服务器,我们并不需要知道真正为我们服务的服务器的IP地址,我们只需要向我们的代理服务器发送请求,代理服务器便会为我们自动分配一个,怔怔地服务器,让后将我们需要的数据发送回来。

从图中我们可以发现:正向代理可以隐藏客户端的信息,而反向代理可以隐藏真正服务器的信息,我们看图可以发现,无论正向代理还是反向代理,他的代理服务器的任务都是接受请求和发送响应,

二.我们为什么要用nginx呢?

由上面的介绍我们可以知道什么叫做正向代理和反向代理,我们的nginx就是反向代理,反向代理,在传统的web服务中(正向代理)我们的用户量小,用户直接访问源服务器,但是你有没有想过一个问题,如果这个服务器的用户量非常大,当你访问这个源服务器的时候,其他人正在访问这个服务,这个时候,你就没有办法获取服务了,这个时候我们就可能会想到,我们可以多增加几个源服务器,当我们来访问这个服务的时候,会有一个专门的服务用来将我们的请求分配到空闲的服务器上,这个就是nginx的负载均衡,这个时候我们就会用到反向代理,也就是nginx,负载均衡后面我们会讲。

三.nginx怎么用

当我们下载了nginx之后我们让nginx来监听一个端口,但实际上当我们要访问这个代理服务器的的这个端口的时候,他就会转发给后边真正要处理的服务器,也就是源服务器,由他来真正的处理这个服务,当处理完这个服务之后,源服务器并不会直接将信息发送给客户端,而是将信息发送给代理服务器,由他发送给我们的客户端,这样客户端就会认为处理他们请求的服务器就是这个代理服务器,但实际上处理这个服务的服务器是他后边的源服务器,而这个时候我们就可以将一些静态的东西存放在nginx这个代理服务器上。

四.负载均衡

负载均衡:当我们拥有多个服务器的时候,我们就需要对这些服务器进行一些规划,总不能让一些服务器的负载都快到100%了,而有一些服务器的负载还在10%左右,我们要对我们的服务请求,进行分配,让他们负载都在一个合理的区间,这就是负载均衡,当你理解了上面的负载均衡之后,你也就知道我们为什么要用负载均衡了。

负载均衡怎么用?

我们nginx有好几种负载均衡的方法:轮询、加权轮询算法、负载量最低优先、hash算法等等。

轮询算法:负载均衡系统收到请求后,按照顺序轮流分配到服务器上。

加权轮询算法:这里的加权一般是根据硬件配置进行静态配置的,加权轮询是轮询的一种特殊形式,其主要目的就是为了解决不同服务器处理能力有差异的问题。

负载量最低优先:当代理服务器接受到请求的时候,他就会根据每个服务器的连接数、http请求数、CPU负载等情况来进行选择。

hash算法:负载均衡系统根据任务中的某些关键信息进行 Hash 运算,将相同 Hash 值得请求分配到同一台服务器上。

我们在nginx中的负载均衡就需要设置一些配置、算法,根据这些来进行负载均衡,这个我们要修改nginx.conf文件,来进行设置,我这里有一张nginx.conf的文件内部的照片,可以来看一下

如果我们要进行负载均衡,可以将内容写到http{}这个大括号里面,在这里我们可以设置我们的负载均衡使用的方法,默认为轮询,也可以用其他的如:增加weight(权重)、IP_hash(依据IP进行分配)、least_conn(依据最少连接数进行划分)等等,我们也可以对我们的代理服务器进行设置:暴露的端口、服务器默认的页面、定义错误页面信息、等等。