43 Star 208 Fork 85

WeBank / DeFiBus

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
4-invoke-service-nearby.md 2.08 KB
一键复制 编辑 原始数据 按行查看 历史
qqeasonchen 提交于 2019-10-31 10:11 . init repository

4.服务就近

       为了保证高可用,服务的部署通常分布在多个机房、区域。我们希望服务之间能够就近调用,减少跨机房跨区域网络访问的时延问题。对此,DeFiBus在Broker和客户端上都增加了区域的属性来标识实例属于哪个区域。对于Producer,消息会优先发往同区域内的Broker集群上;对于Consumer,则优先监听同区域内的Queue;当一个区域内没有Consumer实例监听时,则由其他区域的Consumer实例跨区域监听。

就近发送

       在创建Producer时,通过设置DeFiBusClientConfig.setClusterPrefix("your region")来标识Producer实例所在的区域。Producer在每次发送消息会先选则一个Queue来作为发送的目标队列。当启用就近发送时,Producer优先选择与自己同区域内的Queue,当本区域内没有可用Queue时,则选择其他区域的Queue。

就近监听

       就近监听指的是Consumer在做负载均衡分配Queue的时候,每个区域内的Queue只由该区域内的Consumer监听和消费,当且仅当一个区域内没有订阅该Topic的Consumer时,由其他区域订阅了该Topic的Consumer跨区域监听和消费这些Queue。虽然Consumer是在同区域内就近消费,但仍通过心跳维持跨区域的连接,以保证能够随时跨区域接管消费。


Links:

Java
1
https://gitee.com/WeBank/DeFiBus.git
git@gitee.com:WeBank/DeFiBus.git
WeBank
DeFiBus
DeFiBus
master

搜索帮助