nginx的负载均衡

本文来自 http://nginx.org/en/docs/http/load_balancing.html#nginx_load_balancing_methods

1. 简介

跨多个应用实例的负载均衡(load balancing)是优化资源利用率(optimizing resource utilization),最大化吞吐量(maximizing throughput),减少延迟(reducing latency),确保容错配置(ensuring fault-tolerant configurations)的通用方法。

可以使用nginx作为一个非常有效的HTTP负载均衡器,将流量分配到多个应用服务器,并使用nginx提高web应用程序的性能可伸缩性可靠性

2. 负载均衡策略

nginx支持以下负载均衡策略(或方法):

  • 轮询(round-robin)—— 将请求以轮询的方式分发给服务器
  • 最少连接(least-connected)—— 将请求分配给活动连接最少的服务器
  • IP 哈希(ip-hash)—— 使用一个hash函数(基于客户机的IP地址)来确定请求应该分发给哪个服务器。

2.1. 默认负载均衡配置

http {
    upstream myapp1 {
        server srv1.example.com;
        server srv2.example.com;
        server srv3.example.com;
    }
    server {
        listen 80;
        location / {
            proxy_pass http:\\myapp1;  // 这里应该是 http://myapp1 但是我不会转格式 
        }
    }
}

在上面的示例中,同一个应用程序有3个实例运行在srv1-srv3上。如果没有特别配置负载均衡策略,则默认为轮询。所有请求都代理到服务器组myapp1, nginx应用HTTP负载均衡来分发请求。

nginx中的反向代理实现包括HTTP、HTTPS、FastCGI、uwsgi、SCGI、memcached和gRPC的负载平衡。

在为FastCGI、uwsgi、SCGI、memcached或gRPC设置负载均衡时,分别使用fastcgi_pass、uwsgi_pass、scgi_pass、memcached_pass和grpc_pass指令。

2.2. 最少连接负载均衡

upstream myapp1 {
    least_conn;
    server srv1.example.com;
    server srv2.example.com;
    server srv3.example.com;
}

2.3. 持久性会话

请注意,通过轮询或最少连接的负载均衡,每个客户机的请求可能分布到不同的服务器。不能保证将相同客户机的请求定向到特定的服务器
如果需要将客户机绑定到特定的服务器——换句话说,使客户机的会话具有“粘性”或“持久性”,以便总是选择特定的服务器——那么可以使用ip-hash负载均衡机制
使用ip-hash时,将客户机的IP地址用作散列key,以确定应该为客户机请求选择服务器组中的哪个服务器。此方法确保来自同一客户机的请求总是指向同一服务器,除非该服务器不可用

upstream myapp1 {
    ip_hash;
    server srv1.example.com;
    server srv2.example.com;
    server srv3.example.com;
}

2.4. 加权负载均衡

还可以通过使用服务器权重进一步影响nginx负载均衡算法。
在上面的示例中,没有配置服务器权重,这意味着对于特定的负载均衡策略,所有的服务器都被同等对待。
特别是对于轮循,它还意味着请求在服务器上的分布是均等的——只要有足够的请求,并且当请求以统一的方式处理并足够快地完成时。
当为服务器指定权重参数时,该权值将作为负载均衡决策的一部分

upstream myapp1 {
    server srv1.example.com weight=3;
    server srv2.example.com;
    server srv3.example.com;
}

3. 健康检查

nginx中的反向代理实现包括 in-band(或 passive)服务器健康检查。如果来自特定服务器的响应失败并出现错误,nginx会将此服务器标记为 failed,并暂时避免为后续的请求选择此服务器。

max_failed 指令设置在 fail_timeout 期间尝试与服务器通信的连续失败次数。默认情况下,max_failed设置为1。将其设置为0时,将禁用此服务器的健康检查。fail_timeout参数还定义了服务器被标记为 failed 的时间长度。在服务器故障之后的 fail_timeout 时间间隔之后,nginx将开始使用活动客户机请求优雅地探测服务器 。如果探测成功,则将服务器标记为活动的探测。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 162,408评论 4 371
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,690评论 2 307
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 112,036评论 0 255
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,726评论 0 221
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 53,123评论 3 296
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 41,037评论 1 225
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,178评论 2 318
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,964评论 0 213
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,703评论 1 250
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,863评论 2 254
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,333评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,658评论 3 263
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,374评论 3 244
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,195评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,988评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,167评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,970评论 2 279

推荐阅读更多精彩内容

  • 大家好,我是IT修真院深圳分院第5期学员,一枚正直善良的JAVA程序员。 今天给大家分享一下,修真院官网JAVA任...
    东_214a阅读 439评论 0 0
  • 一、简单需求 1.使用nginx对请求进行负载。负载分配到自身服务器和另外一台服务器。 二、知识普及 1、ngin...
    Magic_X阅读 1,801评论 0 3
  • 1.upstream模块 upstream模块介绍Nginx的负载均衡功能依赖于ngx_http_upstream...
    xhz的个人小屋阅读 431评论 0 1
  • 有时候,我工作着,来了微:你在干嘛?我微微一笑:上课! 有时候,我河堤小走,来了微:你在哪里?我嘴角上翘:跑步! ...
    湍河故事阅读 389评论 2 4
  • 中国传统文化的方法论,是以全能的视角审视他人,并以全能的方式控制他人;人们无法用第三方视角来观察自己与他人。因而,...
    正洪观点阅读 1,385评论 0 2