1、正向代理:
比如国内想要访问一些被屏蔽的外部网站,需要先将请求发到代码服务器,代理服务器收到请求后转发到对象服务器,再将返回的数据返回给客户端。
正向代理最大的特点是客户端非常明确要访问的服务器地址;服务器只清楚请求来自哪个代理服务器,而不清楚来自哪个具体的客户端;正向代理模式屏蔽或者隐藏了真实客户端信息。
2、反向代理:
比如我们访问淘宝,由于访问人数众多,单个服务器无法处理超大的负载,所以后台服务器部署会进行多台服务器的分布式部署。
但是我们的入口只有一个域名,请求会被发送到反向代理服务器,代理服务器通过一定的规则,再分发到后台的单个服务器。
请求的来源也就是客户端是明确的,但是请求具体由哪台服务器处理的并不明确了,nginx扮演的就是一个反向代理角色。
反向代理,主要用于服务器集群分布式部署的情况下,反向代理隐藏了服务器的信息!
3、负载均衡
负载均衡在实际项目操作过程中,有硬件负载均衡和软件负载均衡两种,硬件负载均衡也称为硬负载,如F5负载均衡,相对造价昂贵成本较高,但是数据的稳定性安全性等等有非常好的保障,如中国移动中国联通这样的公司才会选择硬负载进行操作;更多的公司考虑到成本原因,会选择使用软件负载均衡,软件负载均衡是利用现有的技术结合主机硬件实现的一种消息队列分发机制
nginx支持的负载均衡调度算法方式如下:
- weight轮询(default)
接收到的请求按照顺序逐一分配到不同的后端服务器,即使在使用过程中,某一台后端服务器宕机,nginx会自动将该服务器剔除出队列,请求受理情况不会受到任何影响。 这种方式下,可以给不同的后端服务器设置一个权重值(weight),用于调整不同的服务器上请求的分配率;权重数据越大,被分配到请求的几率越大;该权重值,主要是针对实际工作环境中不同的后端服务器硬件配置进行调整的。
- ip_hash
根据发起客户端的ip hash进行匹配,这样以来,一个ip就能访问固定的一台后端服务器,这也一定程度上解决了集群部署下session共享的问题。
- fair
智能调整调度算法,动态的根据后端服务器的请求处理到响应的时间进行均衡分配,响应时间短处理效率高的服务器分配到请求的概率高,响应时间长处理效率低的服务器分配到的请求少;结合了前两者的优点的一种调度算法。但是需要注意的是nginx默认不支持fair算法,如果要使用这种调度算法,请安装upstream_fair模块
- url_hash
根据访问请求的url hash进行分配,每个请求的url会指向固定的某台服务器,可以在nginx作为静态服务器的情况下提高缓存效率。默认不支持,需安装nginx的hash软件包