首页 > 编程知识 正文

nginx反向代理缓存(nginx同时正向代理和反向代理)

时间:2023-05-06 04:56:40 阅读:1250 作者:2881

Nginx配置详解

10-1010 inx是一款免费、开源、高性能的HTTP服务器和反向代理服务器。它也是一个IMAP,POP3和SMTP的代理服务器。Nginx可以作为HTTP服务器发布网站,nginx可以作为反向代理实现负载均衡。

这里从三个方面简要介绍nginx。

反向代理负载平衡nginx功能1。反向代理

关于代理

说到代理,首先要定义一个概念。所谓代理,就是一个代表,一个渠道。

此时,设计了两个角色,一个是主体角色,另一个是目标角色。主体角色通过此代理访问目标角色以完成某些任务的过程称为代理操作过程。就像生活中的专卖店~一位客人在阿迪达斯专卖店买了一双鞋。这家专卖店是代理商,主要角色是阿迪达斯制造商,目标角色是用户。

转发代理

在讨论反向代理之前,我们先来看看正向代理,这也是我们最熟悉的代理模式。我们将从软件和生活两个方面来解释什么是正向代理。

在当今的网络环境下,如果我们因为技术需求想要访问一些国外的网站,那么你会发现我们是没有办法通过浏览器访问位于国外的网站的。此时,每个人都可以使用FQ行动来访问它。FQ的主要方式是找一个可以访问国外网站的代理服务器。我们将请求发送到代理服务器,代理服务器将访问国外网站,然后将访问的数据传递给我们!

上述代理模式称为前向代理,前向代理最大的特点是客户端非常清楚要访问的服务器地址;服务器只知道请求来自哪个代理服务器,而不知道请求来自哪个特定的客户端。前向代理模式屏蔽或隐藏真实的客户端信息。

反向代理

了解了什么是正向代理,我们继续来看看如何处理反向代理。比如,每天同一时间连接网站的访客数量已经达到了无以复加的地步,单一的服务器远远不能满足人们日益增长的购买欲望。这时,一个熟悉的术语出现了:分布式部署;即通过部署多台服务器解决访客数量有限的问题;一个宝藏网站的大部分功能都是用nginx进行反向代理直接实现的,封装nginx和其他组件后,就有了一个高大的名字:tenengine。感兴趣的童鞋可以登陆tenengine官网查看具体信息:http://tengine.taobao.org/.

那么,反向代理到底是如何实现分布式集群操作的呢?我们先来看一个示意图:

从上图中我们可以清楚地看到,nginx服务器收到多个客户端发送到服务器的请求后,按照一定的规则分发到后端业务处理服务器进行处理。此时,请求的来源(即客户端)是明确的,但不清楚哪个服务器将处理该请求。nginx扮演反向代理的角色。

反向代理,主要用于服务器集群的分布式部署,隐藏了服务器的信息!

项目场景

在正常情况下,当我们实际操作项目时,正向代理和反向代理很可能存在于一个应用场景中。前向代理客户端请求访问目标服务器。目标服务器是一个反向简单服务器,反向代理服务器代表几个真实的业务处理服务器。的具体拓扑图如下:

2.负载平衡

我们已经定义了所谓代理服务器的概念。然后,nginx扮演反向代理服务器的角色。它根据什么规则分发请求?没有项目的应用场景,分发规则能控制吗?

这里提到的客户端发送和nginx反向代理服务器接收的请求数量就是我们所说的负载。

将请求的数量按照一定的规则分配到不同的服务器进行处理的规则是一种平衡规则。

因此,根据规则分发服务器收到的请求的过程称为负载平衡。

在实际项目运行过程中,负载均衡有两种:硬件负载均衡和软件负载均衡。硬件负载均衡也叫硬负载,比如F5负载均衡,成本相对较高,但是数据的稳定性和安全性有很好的保障。中国移动、中国联通等公司将选择硬负荷运营。考虑到成本,更多的公司会选择使用软件负载均衡,这是一种利用现有技术和主机硬件实现的消息队列分发机制。

p>

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

weight轮询(默认):接收到的请求按照顺序逐一分配到不同的后端服务器,即使在使用过程中,某一台后端服务器宕机,nginx会自动将该服务器剔除出队列,请求受理情况不会受到任何影响。 这种方式下,可以给不同的后端服务器设置一个权重值(weight),用于调整不同的服务器上请求的分配率;权重数据越大,被分配到请求的几率越大;该权重值,主要是针对实际工作环境中不同的后端服务器硬件配置进行调整的。ip_hash:每个请求按照发起客户端的ip的hash结果进行匹配,这样的算法下一个固定ip地址的客户端总会访问到同一个后端服务器,这也在一定程度上解决了集群部署环境下session共享的问题。fair:智能调整调度算法,动态的根据后端服务器的请求处理到响应的时间进行均衡分配,响应时间短处理效率高的服务器分配到请求的概率高,响应时间长处理效率低的服务器分配到的请求少;结合了前两者的优点的一种调度算法。但是需要注意的是nginx默认不支持fair算法,如果要使用这种调度算法,请安装upstream_fair模块url_hash:按照访问的url的hash结果分配请求,每个请求的url会指向后端固定的某个服务器,可以在nginx作为静态服务器的情况下提高缓存效率。同样要注意nginx默认不支持这种调度算法,要使用的话需要安装nginx的hash软件包

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。