`
wangking717
  • 浏览: 263192 次
  • 性别: Icon_minigender_2
  • 来自: 成都
社区版块
存档分类
最新评论

Nginx的配置与部署研究,Upstream负载均衡模块

 
阅读更多

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负载均衡部署

    通过配置Nginx的upstream模块,我们可以定义不同的负载均衡策略,如轮询、权重轮询、最少连接数等。下面我们将详细讲解如何配置和使用这些策略。 首先,我们需要在Nginx配置文件`nginx.conf`中设置一个上游服务器组...

    Nginx负载均衡配置

    首先,要配置Nginx与Tomcat实现负载均衡,需要准备两个Tomcat实例,每个实例可以部署一个简单的Web项目,例如通过在页面上标注不同的端口号,以便区分它们。部署完成后,需要配置Nginx的nginx.conf文件,使其成为一...

    nginx+eureka实现负载均衡实例

    - **配置负载均衡**:在 Nginx 配置文件中,通过 `upstream` 块定义一组服务器,并在 `server` 块中指定使用哪个 `upstream`。例如: ``` upstream backend { server backend1.example.com; server backend2....

    nginx负载均衡配置,宕机自动切换方式

    在nginx中进行负载均衡配置,一般会利用到默认安装的ngx_http_proxy_module模块和ngx_http_upstream_module模块。这些模块内嵌于nginx之中,提供了核心的代理和负载均衡功能。通过配置文件nginx.conf中的upstream...

    Nginx+tomcat配置集群负载均衡实例

    本实例将详细阐述如何通过Nginx配置集群负载均衡,以实现动静分离,提升系统性能和稳定性。 首先,Nginx是一款轻量级的Web服务器/反向代理服务器,以其高性能、稳定性以及低内存占用著称。它能处理静态文件请求,...

    nginx应用部署和负载均衡应用

    【Nginx应用部署与负载均衡】 Nginx是一款高性能的HTTP和反向代理服务器,广泛应用于互联网领域,提供高效稳定的服务。它以其轻量级的进程模型、强大的并发处理能力以及优秀的性能表现,成为许多企业的首选Web...

    Nginx负载均衡搭建及配置技术

    Nginx 的负载均衡配置主要通过 `upstream` 模块实现,它可以将请求分发到多个后端服务器。例如: ```nginx upstream backend { server backend1.example.com weight=5; server backend2.example.com; server ...

    Nginx+keepalived+tomcat实现性负载均衡(包含需要的包)

    在Nginx配置文件中,你可以设置upstream模块来定义后端Tomcat服务器的列表和负载均衡策略。 2. 安装Tomcat:部署多个Tomcat实例,每个实例运行在不同的端口上,以处理来自Nginx的请求。 3. 安装keepalived:解压`...

    最新Nginx1.9.4+Tomcat+Memcached负载均衡配置.rar

    用户需要按照文档的指示,正确配置这些组件,包括设置Nginx的upstream模块以定义后端服务器,配置Memcached以存储和检索数据,以及调整Tomcat服务器以适应集群环境。 总之,Nginx 1.9.4、Tomcat和Memcached的组合...

    张宴 使用Nginx轻松实现开源负载均衡

    在Nginx的配置文件(nginx.conf)中,可以通过`http`、`upstream`和`server`等块级结构定义负载均衡策略。例如: ```nginx http { upstream backend { server backend1.example.com weight=3; server backend2...

    nginx-upstream-fair-master.zip

    Nginx的公平负载均衡模块对于大型网站或者高并发应用来说非常重要,因为它能够有效地减少服务器之间的压力差异,提高整体系统的稳定性和响应速度。但需要注意的是,公平负载均衡可能会增加一定的系统复杂性,因此在...

    Nginx+Tomcat高性能负载均衡集群搭建(模板).zip

    2. **配置负载均衡**: 在Nginx的配置文件`nginx.conf`或其包含的虚拟主机配置文件中,添加负载均衡配置。例如,使用轮询策略(round-robin): ```nginx upstream tomcat_cluster { server tomcat1.example....

    nginx-upstream-jvm-route-1.15

    用户需要按照文档的指示进行配置和部署,以便在Nginx 1.15中成功使用upstream模块与JVM的路由功能。 总的来说,"nginx-upstream-jvm-route-1.15"是一个针对Nginx 1.15版本的解决方案,它允许用户通过upstream模块更...

    Nginx负载均衡集群配置文档

    本文档将深入探讨如何配置Nginx来实现对Tomcat应用服务器的负载均衡,以提高系统的稳定性和效率。 一、Nginx简介 Nginx以其轻量级的进程模型、高效的并发处理能力以及丰富的模块化设计,成为部署静态资源和代理服务...

    nginx_upstream_hash-0.3.2.tar.gz

    总结来说,nginx_upstream_hash模块为nginx的负载均衡提供了更精细化的控制,通过合理的配置,可以在复杂环境中实现高效的请求分发,提高系统的稳定性和性能。0.3.2版本的发布,进一步优化了该模块的功能,使其在...

    nginx_tomcat_redis搭建负载均衡共享session

    这通常涉及编辑nginx.conf配置文件,设置 upstream 模块来定义后端服务器组,以及使用 proxy_pass 指令将请求转发到这些服务器。 2. **安装和配置Tomcat**:在多台服务器上安装Tomcat,确保应用部署一致,禁用每个...

    Linux搭建Nginx集群步骤+详细配置

    在`/etc/nginx/nginx.conf`中,我们需要配置Nginx的主配置文件,以启用负载均衡模块: ```nginx http { upstream backend { server backend1.example.com; server backend2.example.com; # 可以添加更多服务器 ...

    Consul+upsync+Nginx动态配置负载均衡.pdf

    【Consul+upsync+Nginx动态配置负载均衡】 Consul+upsync+Nginx的组合提供了一种高效且灵活的动态负载均衡解决方案,它允许Nginx在无需重启的情况下实时更新其配置,以响应后端服务器的变化。这种技术特别适用于高...

    实现基于nginx的tomcat负载均衡和集群配置

    本篇文章将详细讲解如何使用Nginx作为反向代理服务器来实现对Tomcat应用服务器的负载均衡和集群配置。 首先,我们需要理解Nginx和Tomcat的角色。Nginx是一款高性能的HTTP和反向代理服务器,常用于处理静态内容和...

Global site tag (gtag.js) - Google Analytics