nginx负载均衡算法有哪些_dubbo负载均衡算法

nginx负载均衡算法有哪些_dubbo负载均衡算法nginx负载均衡的几种算法

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

前言: 在 nginx 中,我们通过 upstream 命令来实现的,由 ngx_http_upstream_module 模块提供支持。

nginx 负载均衡算法

  • 1:轮询(默认)
    每个请求按照时间顺序逐一分配到下游的服务节点,如果其中某一节点故障,nginx 会自动剔除故障系统使用户使用不受影响。
  • 2.权重(weight)
    在配置文件中对下游的服务节点指定权重值 weight, weight 值越大则被分配的评率越高,一般这种负载均衡,用于节点的配置情况不一样,有的可能配置高,有的配置低。
  • 3.ip_hash
    对每个请求,针对 ip 进行 hash, 然后分配到后台节点,这样一来,同一 ip 会被固定分配到下游固定服务上。它能够暂时的解决集群环境中容器之间 session 共享的问题,但是不是解决的根本之道,只是权宜之策,我们试想,如果访问的好好的,家里的路由器被重启了,或者运营商分配给你的 ip 地址改变了,那么你再次访问的时候,新的 ip 就可能被分配到新的服务上,之前的 session 也就失效了。
  • 4.least_conn (最少连接调度算法)
    最少连接调度算法,对下游服务中连接情况,优先选择连接数最少的服务分配。
  • 5.least_time (最小响应时间)
    最小响应时间, 计算节点平均响应时间,然后取响应最快的那个,分配更高权重。

upstream 中可附加指令

  • down,表示当前的 server 不参与负载均衡。
  • backup, 预留的备份机,当其他所有非 backup 的机器出现故障或者忙的时候,才会请求 backup 机器,因此这台机器的压力最轻。
  • max_fails,允许请求失败的次数,默认为 1,当超过最大次数时,返回 proxy_next_upstream 模块定义的错误。
  • fail_timeout, 在经历了 max_fails 次失败后,暂停服务的时间,max_fails 可以和 fail_timeout 一起使用。
  • keepalive 连接数 N; 为每个 worker 进程保留的空闲的长连接数量, 可节约 nginx 端口,并减少连接管理的消耗

如何配置?

  • 轮询负载
upstream webserver { 
   
				server 192.168.214.133:80 max_fails=3 fail_timeout=30s;
				server 192.168.214.187:80 max_fails=3 fail_timeout=30s;
		}

测试:

[root@nfs ~]# for i in { 
   1..10};do curl www.a.com/index.html;done
web server 1 page
web server 2 page
web server 1 page
web server 2 page
web server 1 page
web server 2 page
web server 1 page
web server 2 page
web server 1 page
web server 2 page
  • 加权轮询
upstream webserver { 
   
		 server 192.168.214.133:80 weight=3 max_fails=3 fail_timeout=30s;
		 server 192.168.214.187:80 max_fails=3 fail_timeout=30s;
		}

测试:

[root@nfs ~]# for i in { 
   1..10};do curl www.a.com/index.html;done
web server 2 page
web server 1 page
web server 1 page
web server 1 page
web server 2 page
web server 1 page
web server 1 page
web server 1 page
web server 2 page
web server 1 page
  • ip_hash
upstream webserver { 
   
				ip_hash;
				server 192.168.214.133:80 max_fails=3 fail_timeout=30s;
				server 192.168.214.187:80 max_fails=3 fail_timeout=30s;
		}

测试:

[root@nfs ~]# for i in { 
   1..10};do curl www.a.com/index.html;done
web server 2 page
web server 2 page
web server 2 page
web server 2 page
web server 2 page
web server 2 page
web server 2 page
web server 2 page
web server 2 page
web server 2 page
  • least_conn 最少连接
upstream webserver { 
   
				least_conn;
				server 192.168.214.133:80 weight=3 max_fails=3 fail_timeout=30s;
				server 192.168.214.187:80 max_fails=3 fail_timeout=30s;
		}

测试:

[root@nfs ~]# for i in { 
   1..10};do curl www.a.com/index.html;done
web server 1 page
web server 1 page
web server 2 page
web server 1 page
web server 1 page
web server 1 page
web server 2 page
web server 1 page
web server 1 page
web server 1 page

原文地址:https://www.exception.site/article/20

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182771.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Matlab中fprintf函数使用[通俗易懂]

    Matlab中fprintf函数使用[通俗易懂]fprintf函数将数据写入文本文件。语法fprintf(fileID,formatSpec,A1,…,An)fprintf(formatSpec,A1,…,An)nbytes=fprintf(___)说明fprintf(fileID,formatSpec,A1,…,An)按列顺序将formatSpec应用于数组A1,…An的所有元素,并将数据写入到一个文本文件。fprintf使用在对fopen的调用中指定的编码方案。fprintf(form…

    2022年10月19日
    4
  • idea查看激活码-激活码分享[通俗易懂]

    (idea查看激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月26日
    71
  • 操作系统知识点整理(完整版)

    操作系统知识点整理(完整版)第一章操作系统概述1)一个完整的计算机系统是由硬件系统和软件系统两大部分组成2)计算机软件是指程序和与程序相关的文档的集合3)按功能可把软件分为“系统软件”和“应用软件”两部分系统软件:操作系统语言处理程序,数据库管理系统应用软件:各种管理软件,用于工程计算的软件包,辅助设计软件4)通常把未配置任何软件的计算机称为“裸机”5)操作系统可以被看作是计算机系统的核心,统管…

    2022年6月25日
    51
  • c++链式前向星_链式基数排序图解

    c++链式前向星_链式基数排序图解图的存储方法很多,最常见的除了邻接矩阵、邻接表和边集数组外,还有链式前向星。链式前向星是一种静态链表存储,用边集数组和邻接表相结合,可以快速访问一个顶点的所有邻接点,在算法竞赛中广泛应用。链式前向星存储包括两种结构:边集数组:edge[],edge[i]表示第i条边; 头结点数组:head[],head[i]存以i为起点的第一条边的下标(在edge[]中的下标)structnode{intto,next,w;}edge[maxe];//边集数组,边数一般要设置比ma…

    2025年7月17日
    3
  • 自然语言处理真实项目实战(20170822)

    自然语言处理真实项目实战(20170822)

    2022年3月6日
    46
  • git命令

    git命令

    2022年3月7日
    44

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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