英文原文地址:http://nginx.org/en/docs/http/ngx_http_upstream_module.html

大纲:

  1. 示例
  2. 指令
  3. 嵌入变量

ngx_http_upstream_module模块用来定义一个可以通过proxy_pass, fastcgi_pass和memcached_pass指令引用的服务器群组

示例配置

 upstream backend {
server backend1.example.com weight=;
server backend2.example.com:;
server unix:/tmp/backend3; server backup1.example.com: backup;
server backup2.example.com: backup;
} server {
location / {
proxy_pass http://backend;
}
}

动态配置服务器组仅仅在商业版本中可以使用

示例:

 upstream appservers {
zone appservers 64k; server appserv1.example.com weight=;
server appserv2.example.com: fail_timeout=5s slow_start=30s;
server 192.0.2.1 max_fails=; server reserve1.example.com: backup;
server reserve2.example.com: backup;
} server {
location / {
proxy_pass http://appservers;
health_check;
} location /upstream_conf {
upstream_conf;
allow 127.0.0.1;
deny all;
}
}

指令

upstream

语法: upstream name {...}
default:--
context:http

示例:

upstream backend {
server backend1.example.com weight=;
server 127.0.0.1: max_fails= fail_timeout=30s;
server unix:/tmp/backend3;
}

默认情况下,请求会根据权重循环分发到各个服务器。在上面的例子中,每7个请求的分发方法如下:5个请求发给backend1.example.com,第二和第三个服务器分别分发一个请求。如果在通讯过程中一个服务器出现了问题,则这次的请求会被分发给下一个服务器,以此类推,知道所有的服务器都被尝试过一次。如果从所有的服务器中都无法成功请求,客户端会收到最后一个服务器的结果。

server

 语法:    server address [parameters];
default: —
context: upstream

给一个服务器指定一个地址和其它参数。地址可以指定为域名或ip(可以指定端口),或使用添加“unix:”前缀的unix套接字(unix-domain socket)。在未指定端口的情况下,默认使用80端口。一个域名解析到多个ip相当于一次设定了多个服务器。(感觉翻译的很别扭)

下面是server中可设定的参数:

  • weight=number

    设置服务器的权重,默认值为1(值越大表示权重越高)

  • max_fails=number

    设置服务器最大的失败请求次数(中间还有很多。。。)。默认情况下失败请求次数为1,如果设置为0表示禁用请求计数。在proxy_next_upstream,fastcgi_next_upstream, and memcached_next_upstream 指令中也考虑到了失败请求次数。

  • fail_timeout=number

    设置: 

    • 请求失败超过特定次数视为服务器不可用
    • 请求超时视为服务器不可用

    默认情况下此参数的值为10秒

  • slow_start=time

    当一个服务器从不健康变为健康或从不可用到可用时设置过多长时把服务器的权重从0恢复为原设置的值。默认值为1,即是被禁用的。

    注:仅商业版可用

  • backup

    把此服务器标记为备用服务器。当主服务器不可用时会把请求分发到备用服务器。

  • down

    把一个服务器标记为永久不可用;通常和 ip_hash指令一起使用

示例:

 upstream backend {
server backend1.example.com weight=;
server 127.0.0.1: max_fails= fail_timeout=30s;
server unix:/tmp/backend3; server backup1.example.com: backup;
}

  

注:如果在服务器组中只有一个服务器,max_fails,fail_time_outslow_start参数将会被忽略,而且这个服务器也永远不会被标记为不可用

zone

syntax:    zone name size;
default: —
context: upstream

[Nginx][HttpUpstreamModule]翻译负载均衡的更多相关文章

  1. 【翻译】Nginx的HTTP负载均衡

    本文为翻译文,原文地址:http://nginx.org/en/docs/http/load_balancing.html 介绍 将请求负载均衡到多个应用实例是一个常用的技术,它起到优化资源使用率.最 ...

  2. nginx安装及负载均衡配置

    Nginx (“engine x”) 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. Nginx 是由 Igor Sysoev 为俄罗斯访问量第二 ...

  3. Nginx 简单的负载均衡配置示例(转载)

    原文地址:Nginx 简单的负载均衡配置示例(转载) 作者:水中游于 www.s135.com 和 blog.s135.com 域名均指向 Nginx 所在的服务器IP. 用户访问http://www ...

  4. 观nginx与lvs负载均衡的较量

    在技术工作者中,常用到的就是lvs负载均衡和Nginx负载均衡了.这两者也是比较普及的.那么,根据不同的需求,两者存在着不同的优势.具体选择哪一个,还要看您的要求了.那么我们在此为大家分享一篇文章,对 ...

  5. 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器

    Hi, 今天我们将会学习如何使用 Weave 和 Docker 搭建 Nginx 的反向代理/负载均衡服务器.Weave 可以创建一个虚拟网络将 Docker 容器彼此连接在一起,支持跨主机部署及自动 ...

  6. Nginx+Tomcat+Memcached负载均衡集群服务搭建

    操作系统:CentOS6.5  本文档主要讲解,如何在CentOS6.5下搭建Nginx+Tomcat+Memcached负载均衡集群服务器,Nginx负责负载均衡,Tomcat负责实际服务,Memc ...

  7. 基于nginx的tomcat负载均衡和集群

    要集群tomcat主要是解决SESSION共享的问题,因此我利用memcached来保存session,多台TOMCAT服务器即可共享SESSION了. 你可以自己写tomcat的扩展来保存SESSI ...

  8. nginx+tomcat+redis负载均衡及session共享

    概述 本文档是用来详细描述 nginx+tomcat+redis负载均衡实现session共享 所需软件及下载地址 软件名称 下载地址 功能说明 Nginx-v1.6.0 http://nginx.o ...

  9. Nginx 简单的负载均衡配置示例

    http://www.cnblogs.com/xiaogangqq123/archive/2011/03/02/1969006.html 在此记录下Nginx服务器nginx.conf的配置文件说明, ...

随机推荐

  1. Git 分支合并

    理解核心 Git最初只有一个分支,所有后续分支都是直接或间接的从这个分支切出来的. 在任意两个分支上,向前追溯提交记录,都能找到一个最近的提交同时属于这两个分支,这个提交就是两个分支的分叉节点 分支合 ...

  2. Linux内核中双向链表的经典实现

    概要 前面一章"介绍双向链表并给出了C/C++/Java三种实现",本章继续对双向链表进行探讨,介绍的内容是Linux内核中双向链表的经典实现和用法.其中,也会涉及到Linux内核 ...

  3. rsync同步Nginx日志遇到问题总结

    一.目的 将nginx 日志通过普通用户利用rsync公钥认证的方式实时同步到本地服务器上,之后使用elk程序进行处理. 二.遇到问题及解决方法思路 问题1.文件权限:nginx 的日志默认权限如下: ...

  4. JavaScript之旅(二)

    JavaScript之旅(二) 二.进阶知识 js的正则表达式 异常处理 调试 变量提升 表单验证 JSON javascript:void(0) JavaScript 代码规范 二.进阶知识 1. ...

  5. 还在抱怨JS文件里没有智能提示吗, VS10以及以上都可以 .NET

    1.打开JS文件 2.编写$.我们会发现什么也没有 3.托进来 4.有了哈 保存头部代码新建JS都贴上去.

  6. JS 中对象的简单创建和继承

    对象的简单创建 1.通过对象直接量创建 比如 var obj = {}; 2.通过new 创建 比如 var obj = new Object(); // 相当于var obj = {}; var a ...

  7. c++转C#

    //c++:HANDLE(void   *)          ----    c#:System.IntPtr        //c++:Byte(unsigned   char)     ---- ...

  8. 译:什么是ViewData的, ViewBag和TempData? - MVC为当前和后续请求之间传递数据的三种方法

    译文出处:http://www.codeproject.com/Articles/476967/WhatplusisplusViewData-cplusViewBagplusandplusTem AS ...

  9. 【JavaScript回顾】对象创建的几种模式

    组合使用构造函数模式和原型模式 创建自定义类型的常见方式,就是组合使用构造函数模式与原型模式.构造函数模式用于定义实 例属性,而原型模式用于定义方法和共享的属性.结果,每个实例都会有自己的一份实例属性 ...

  10. ASP.NET后台执行JS代码

    1. 用Response.Write方法 代码如下:Response.Write("<script type='text/javascript'>alert("XXX& ...