Nginx 的 HttpUpstreamModule 提供对后端(backend)服务器的简单负载均衡。一个最简单的 upstream 写法如下:
upstream backend { server backend1.example.com; server backend2.example.com; server.backend3.example.com; } server { location / { proxy_pass http://backend; } }
1、后端服务器
通过 upstream 可以设定后端服务器,指定的方式可以是 ip 地址与端口、域名、UNIX 套接字(socket)。其中如果域名可以被解析为多个地址,则这些地址都作为 backend。下面举例说明:
upstream backend { server blog.csdn.net/poechant; server 145.223.156.89:8090; server unix:/tmp/backend3; }
第一个 backend 是用域名指定的。第二个 backend 是用 IP 和端口号指定的。第三个 backend 是用 UNIX 套接字指定的。
2、负载均衡策略
Nginx 提供轮询(round robin)、用户 IP 哈希(client IP)和指定权重 3 种方式。
默认情况下,Nginx 会为你提供轮询作为负载均衡策略。但是这并不一定能够让你满意。比如,某一时段内的一连串访问都是由同一个用户 Michael 发起的,那么第一次 Michael 的请求可能是 backend2,而下一次是 backend3,然后是 backend1、backend2、backend3…… 在大多数应用场景中,这样并不高效。当然,也正因如此,Nginx 为你提供了一个按照 Michael、Jason、David 等等这些乱七八糟的用户的 IP 来 hash 的方式,这样每个 client 的访问请求都会被甩给同一个后端服务器。具体的使用方式如下:
upstream backend { ip_hash; server backend1.example.com; server backend2.example.com; server.backend3.example.com; }
这种策略中,用于进行 hash 运算的 key,是 client 的 C 类 IP 地址(C 类 IP 地址就是范围在 192.0.0.0 到 223.255.255.255 之间,前三段号码表示子网,第四段号码为本地主机的 IP 地址类别)。这样的方式保证一个 client 每次请求都将到达同一个 backend。当然,如果所 hash 到的 backend 当前不可用,则请求会被转移到其他 backend。
再介绍一个和 ip_hash 配合使用的关键字:down。当某个一个 server 暂时性的宕机(down)时,你可以使用“down”来标示出来,并且这样被标示的 server 就不会接受请求去处理。具体如下:
upstream backend { server blog.csdn.net/poechant down; server 145.223.156.89:8090; server unix:/tmp/backend3; }
还可以使用指定权重(weight)的方式,如下:
upstream backend { server backend1.example.com; server 123.321.123.321:456 weight=4; }
默认情况下 weight 为 1,对于上面的例子,第一个 server 的权重取默认值 1,第二个是 4,所以相当于第一个 server 接收 20% 的请求,第二接收 80% 的。要注意的是 weight 与 ip_hash 是不能同时使用的,原因很简单,他们是不同且彼此冲突的策略。
3、重试策略
可以为每个 backend 指定最大的重试次数,和重试时间间隔。所使用的关键字是 max_fails 和 fail_timeout。如下所示:
upstream backend { server backend1.example.com weight=5; server 54.244.56.3:8081 max_fails=3 fail_timeout=30s; }
在上例中,最大失败次数为 3,也就是最多进行 3 次尝试,且超时时间为 30秒。max_fails 的默认值为 1,fail_timeout 的默认值是 10s。传输失败的情形,由 proxy_next_upstream 或 fastcgi_next_upstream 指定。而且可以使用 proxy_connect_timeout 和 proxy_read_timeout 控制 upstream 响应时间。
有一种情况需要注意,就是 upstream 中只有一个 server 时,max_fails 和 fail_timeout 参数可能不会起作用。导致的问题就是 nginx 只会尝试一次 upstream 请求,如果失败这个请求就被抛弃了 : ( ……解决的方法,比较取巧,就是在 upstream 中将你这个可怜的唯一 server 多写几次,如下:
upstream backend { server backend.example.com max_fails fail_timeout=30s; server backend.example.com max_fails fail_timeout=30s; server backend.example.com max_fails fail_timeout=30s; }
4、备机策略
从 Nginx 的 0.6.7 版本开始,可以使用“backup”关键字。当所有的非备机(non-backup)都宕机(down)或者繁忙(busy)的时候,就只使用由 backup 标注的备机。必须要注意的是,backup 不能和 ip_hash 关键字一起使用。举例如下:
upstream backend { server backend1.example.com; server backend2.example.com backup; server backend3.example.com; }
参考网址:http://www.linuxde.net/2012/06/11006.html
相关推荐
通过配置Nginx的upstream模块,我们可以定义不同的负载均衡策略,如轮询、权重轮询、最少连接数等。下面我们将详细讲解如何配置和使用这些策略。 首先,我们需要在Nginx配置文件`nginx.conf`中设置一个上游服务器组...
首先,要配置Nginx与Tomcat实现负载均衡,需要准备两个Tomcat实例,每个实例可以部署一个简单的Web项目,例如通过在页面上标注不同的端口号,以便区分它们。部署完成后,需要配置Nginx的nginx.conf文件,使其成为一...
- **配置负载均衡**:在 Nginx 配置文件中,通过 `upstream` 块定义一组服务器,并在 `server` 块中指定使用哪个 `upstream`。例如: ``` upstream backend { server backend1.example.com; server backend2....
在nginx中进行负载均衡配置,一般会利用到默认安装的ngx_http_proxy_module模块和ngx_http_upstream_module模块。这些模块内嵌于nginx之中,提供了核心的代理和负载均衡功能。通过配置文件nginx.conf中的upstream...
本实例将详细阐述如何通过Nginx配置集群负载均衡,以实现动静分离,提升系统性能和稳定性。 首先,Nginx是一款轻量级的Web服务器/反向代理服务器,以其高性能、稳定性以及低内存占用著称。它能处理静态文件请求,...
【Nginx应用部署与负载均衡】 Nginx是一款高性能的HTTP和反向代理服务器,广泛应用于互联网领域,提供高效稳定的服务。它以其轻量级的进程模型、强大的并发处理能力以及优秀的性能表现,成为许多企业的首选Web...
Nginx 的负载均衡配置主要通过 `upstream` 模块实现,它可以将请求分发到多个后端服务器。例如: ```nginx upstream backend { server backend1.example.com weight=5; server backend2.example.com; server ...
在Nginx配置文件中,你可以设置upstream模块来定义后端Tomcat服务器的列表和负载均衡策略。 2. 安装Tomcat:部署多个Tomcat实例,每个实例运行在不同的端口上,以处理来自Nginx的请求。 3. 安装keepalived:解压`...
用户需要按照文档的指示,正确配置这些组件,包括设置Nginx的upstream模块以定义后端服务器,配置Memcached以存储和检索数据,以及调整Tomcat服务器以适应集群环境。 总之,Nginx 1.9.4、Tomcat和Memcached的组合...
在Nginx的配置文件(nginx.conf)中,可以通过`http`、`upstream`和`server`等块级结构定义负载均衡策略。例如: ```nginx http { upstream backend { server backend1.example.com weight=3; server backend2...
Nginx的公平负载均衡模块对于大型网站或者高并发应用来说非常重要,因为它能够有效地减少服务器之间的压力差异,提高整体系统的稳定性和响应速度。但需要注意的是,公平负载均衡可能会增加一定的系统复杂性,因此在...
2. **配置负载均衡**: 在Nginx的配置文件`nginx.conf`或其包含的虚拟主机配置文件中,添加负载均衡配置。例如,使用轮询策略(round-robin): ```nginx upstream tomcat_cluster { server tomcat1.example....
用户需要按照文档的指示进行配置和部署,以便在Nginx 1.15中成功使用upstream模块与JVM的路由功能。 总的来说,"nginx-upstream-jvm-route-1.15"是一个针对Nginx 1.15版本的解决方案,它允许用户通过upstream模块更...
本文档将深入探讨如何配置Nginx来实现对Tomcat应用服务器的负载均衡,以提高系统的稳定性和效率。 一、Nginx简介 Nginx以其轻量级的进程模型、高效的并发处理能力以及丰富的模块化设计,成为部署静态资源和代理服务...
总结来说,nginx_upstream_hash模块为nginx的负载均衡提供了更精细化的控制,通过合理的配置,可以在复杂环境中实现高效的请求分发,提高系统的稳定性和性能。0.3.2版本的发布,进一步优化了该模块的功能,使其在...
这通常涉及编辑nginx.conf配置文件,设置 upstream 模块来定义后端服务器组,以及使用 proxy_pass 指令将请求转发到这些服务器。 2. **安装和配置Tomcat**:在多台服务器上安装Tomcat,确保应用部署一致,禁用每个...
在`/etc/nginx/nginx.conf`中,我们需要配置Nginx的主配置文件,以启用负载均衡模块: ```nginx http { upstream backend { server backend1.example.com; server backend2.example.com; # 可以添加更多服务器 ...
【Consul+upsync+Nginx动态配置负载均衡】 Consul+upsync+Nginx的组合提供了一种高效且灵活的动态负载均衡解决方案,它允许Nginx在无需重启的情况下实时更新其配置,以响应后端服务器的变化。这种技术特别适用于高...
本篇文章将详细讲解如何使用Nginx作为反向代理服务器来实现对Tomcat应用服务器的负载均衡和集群配置。 首先,我们需要理解Nginx和Tomcat的角色。Nginx是一款高性能的HTTP和反向代理服务器,常用于处理静态内容和...