Dubbo负载均衡策略

发布于 2018-11-24

Dubbo负载均衡策略

Dubbo(读音[ˈdʌbəʊ])是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和 Spring框架无缝集成。Dubbo是一款高性能、轻量级的开源Java RPC框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。

Dubbo提供了多种负载均衡策略,缺省为random随机调用

  • 随机均衡算法
  • 权重轮循算法
  • 最小活跃数算法
  • 一致性hash算法

随机均衡算法 Random LoadBalance

随机,按照权重设置随机概率
调用量越大分布越均匀

权重轮循算法 RoundRobin LoadBalance

轮循,按照权重设置轮循比率
存在问题: 请求累积的问题,请求会累积在性能较差的机器上,导致响应时间慢。
解决办法:把性能差的机器,权重调低。
缺点:无法对机器性能在时间上的变化而做出动态改变,只能人工发现机器性能下降,手动调节权重。

最小活跃数算法 LeastActive LoadBalance

最小活跃调用数,相同活跃数的随机,活跃调用前后计算差值。
处理请求慢的机器将获得更小的调用量,以达到系统处理最大化。
优点:灵活,能够简单的根据调用数量动态调整机器处理的数量。

一致性hash算法 ConsistentHash LoadBalance

一致性hash,相同参数的请求总是发到同一提供者。
如果有一台生产者挂掉,基于虚拟节点,发往其机器的请求平摊到其它机器,不会引起剧烈抖动。
缺省只对第一个参数取hash,如果要修改配置。
缺省只有160个虚拟节点,如果要修改配置。
优点:更加灵活。
缺点:灵活导致难度大,由于粒度 细到单个请求上,一开始在开发时就得规划好,后期变动维护人员难度大。

配置方式

<dubbo:service interface="..." loadbalance="roundrobin"></dubbo:service>
或者
<dubbo:reference interface="..." loadbalance="roundrobin"></dubbo:reference>

随机:loadbalance=”random”
轮循:loadbalance=”roundrobin”
最少活跃数:loadbalance=”leastactive”
一致性Hashloadbalance=”consistenthash”

喜欢 0
奋楫笃行,臻于至善!

相关文章

使用 Mycat 中间件搭建 MySQL 高可用实现分库分表及读写分离

Mycat 是一款基于阿里开源产品Cobar而研发的开源数据库分库分表中间件(基于Java语言开发),可以用来方便地搭建面向企业应用开发的大数据库集群,支持事务、ACID等特性,其核心是基于代理方案实...
阅读全文

通用架构模式和通用架构服务

架构模式是在给定上下文的软件架构中,针对常发生问题的一种通用、复用的解决方案。架构模式类似于软件设计模式,但是范畴更广。一个好的软件产品往往需要有良好的架构思想和架构服务来支撑整个软件的生命周期,本文...
阅读全文

Java 的可重入锁和不可重入锁

可重入锁又名递归锁,是指在同一个线程在外层方法获取锁的时候,再进入该线程的内层方法会自动获取锁(前提锁对象得是同一个对象或者class),不会因为之前已经获取过还没释放而阻塞。Java中Reentra...
阅读全文

Redis 的两种持久化方式及使用场景分析

Redis是内存数据库,数据都是存储在内存中,为了避免进程退出导致数据的永久丢失,需要定期将Redis中的数据以某种形式(数据或命令)从内存保存到硬盘。当下次Redis重启时,利用持久化文件实现数据恢...
阅读全文

redis 高可用主从,哨兵,集群解决方案

Redis因为其高性能和易用性在我们后端的服务中发挥了巨大的作用,并且很多重要功能的实现都会依赖redis。除了常用的缓存,还有队列,发布订阅等重要用处。所以redis的服务高可用就显得尤为关键。这里...
阅读全文

Redis 缓存穿透、缓存击穿、缓存雪崩的区别及解决方案

Redis缓存的使用,极大的提升了应用程序的性能和效率,特别是数据查询方面。但同时,它也带来了一些问题。其中,最要害的问题,就是数据的一致性问题,从严格意义上讲,这个问题无解。如果对数据的一致性要求很...
阅读全文

发表回复

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