Nginx 负载均衡配置和策略「建议收藏」

Nginx 负载均衡配置和策略

大家好,又见面了,我是全栈君。

Nginx 的 HttpUpstreamModule 提供对后端(backend)server的简单负载均衡。一个最简单的 upstream 写法例如以下:

upstream backend {
    server backend1.example.com;
    server backend2.example.com;
    server.backend3.example.com;
}

server {
    location / {
        proxy_pass http://backend;
    }
}

1、后端server

通过 upstream 能够设定后端server,指定的方式能够是 IP 地址与port、域名、UNIX 套接字(socket)。当中假设域名能够被解析为多个地址。则这些地址都作为 backend。

以下举例说明:

upstream backend {
    server blog.csdn.net/poechant;
    server 145.223.156.89:8090;
    server unix:/tmp/backend3;
}

第一个 backend 是用域名指定的。第二个 backend 是用 IP 和port号指定的。

第三个 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 的訪问请求都会被甩给同一个后端server。详细的使用方式例如以下:

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 配合使用的keyword: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 是不能同一时候使用的,原因非常easy,他们是不同且彼此冲突的策略。

3、重试策略

能够为每一个 backend 指定最大的重试次数,和重试时间间隔。

所使用的keyword是 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”keyword。当全部的非备机(non-backup)都宕机(down)或者繁忙(busy)的时候。就仅仅使用由 backup 标注的备机。必需要注意的是,backup 不能和 ip_hash keyword一起使用。

举比例如以下:

upstream backend {
    server backend1.example.com;
    server backend2.example.com backup;
    server backend3.example.com;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/116235.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • StretchDIBits 函数

    StretchDIBits 函数不知道各位有咩有被这个函数搞得很蛋疼,反正我是了,网上的文章很多其实都是到处copy,看了很多然并卵。这个函数的功能和参数就不多说了,蛋疼主要是它画的图片是倒着的,主要问题是怎么把他搞回来。网上的文章说了当目标宽度和源宽度的符号不一样他会做关于x轴的镜像,高度的符号不一样会做Y轴的镜像。好的我的开始函数是这样的StretchDIBits(bufferHDC,0,0,m_nVideoW

  • mapminmax 用法

    mapminmax 用法mapminmax是MATLAB实现归一化的工具包,默认:(1)将矩阵的每行分别进行归一化;(2)每行的最大值最小值作为每行归一化的xmin和xmax;(3)将数据归一化到[-1,1].若要将数据归一化到0到1之间,即y∈[0,1],使用b=mapminmax(a,0,1);若给与确定的最大值和最小值作为每行的xmin和xmax,使用:b= mapminmax(a,0,1);PS.xmin…

  • VMware Ubuntu安装详细过程

    VMware Ubuntu安装详细过程

    2020年11月12日
  • linux安装wget命令_linux下载文件到本地命令

    linux安装wget命令_linux下载文件到本地命令1、检查是否有安装wgetrpm-qa|grep”wget”若存在则移除,以下为移除命令#移除wgetyumremovewget2、登录wget官网下载地址,下载最新的wget的rpm安装包到本地下载地址:http://mirrors.163.com/centos/7/os/x86_64/Packages/3、将下载的wget上传到服务器#/usr/local目录下手动创建一个wget将下载好的wget-1.14-18.el7_6.1.x86_64.rpm上传到此目录下

    2022年10月16日
  • PHP性能提升之opcache「建议收藏」

    PHP性能提升之opcache「建议收藏」     php的不同版本的迭代,都有优化(这是废话),php7,已经出来这么久了,可以说说是相当成熟了,php7的性能提升相对于php5.6等版本的状况,不只是一点儿,而是极大的提升了php的性能。    php自带的缓存有apc,O+。在PHP5.5开始,已经随着PHP的源代码一起发布,并且改名为:Opcache.OPcache 为什么可以优化?   …

  • MySQL Longtext字段优化记录(一)[通俗易懂]

    MySQL Longtext字段优化记录(一)[通俗易懂]Longtext优化记录

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号