dubbo怎么实现consumer从多个group中调用指定group的provider


本篇内容主要讲解“dubbo怎么实现consumer从多个group中调用指定group的provider”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“dubbo怎么实现consumer从多个group中调用指定group的provider”吧!在工作中,遇到这样的场景:有个es索引构建服务,需要从各个业务服务获取索引的信息,从而构建索引,业务服务都实现同一个接口IndexInfoProvider,通过设置不同的group来达到区分的效果(group就是es索引名)。索引构建服务在内存维护了一个Map providerMap,key是索引名——也就是provider的group,value是IndexInfoProvider服务的consumer。为了图方便,索引构建服务还一次性初始化了所有consumer,假设总共有200个分组,那么Map就会缓存200个consumer,初始化的时候巨慢。如果不一次性初始化,而是按需的话,代码会变得复杂一些,可能需要像双重检验这样的措施。而且因为是缓存,必然也会遇到缓存一致性的问题,例如新增一个索引。基于这样的问题,就想着,dubbo的一个consumer,能不能按需调用指定分组的provider呢~为什么有200个分组,就要缓存200个consumer,而不是像我们平时那样,1个就可以呢?业务服务在实现IndexInfoProvider接口的时候,都指定是分组,而且分组名,就是对应的索引名。相应的,消费者就必须指定消费的分组,200个索引,自然就需要200个consumer。在我们日常的使用中,consumer基本都是只能调用一个group的provider。但实际上,dubbo是支持调用多个group的provider的。这样写是指定a分组和b分组,多个分组之间用英文逗号分隔这样写,是所有的分组如果将es索引构建服务的IndexInfoProvider接口的consumer分组设置为group=”*”,然后在调用接口的时候,根据需要,从一堆provider中筛选出指定group的provider,只调用这些provider,是不是就可以代替Map缓存了?初步方案:利用ThreadLocal来指定要调用的分组,在调用方法前设置group到ThreadLocal中。实现dubbo的负载均衡拓展,只选取指定分组的节点来调用。调用结束,清理ThreadLocal中的分组信息。似乎是可行的?通过源码和代码debug发现,consumer持有的Invoker,有点像一个责任链。如果是单分组——!group.contains(“,”) && !group.equals(“*”),那么会是这样:MockClusterInvoker->FailoverClusterInvoker如果是多分组,则会变成:MockClusterInvoker->MergeableClusterInvoker->FailoverClusterInvoker负载均衡的机制,是得到了FailoverClusterInvoker才会生效MockClusterInvoker只是一种降级机制,不是导致问题的原因问题是出在MergeableClusterInvoker,下面是导致问题的代码!!!代码大概的意思是:消费者没有指定合并策略,那么就会调用第一个有效的服务提供者,如果都是无效,就直接调用第一个。我是没有指定合并策略的,所以会变成调用第一个有效的服务提供者。根本走不到负载均衡那里。不指定合并策略不行,那指定呢?指定合并策略会怎样呢?指定了合并策略,会调用所有invoker,然后用Merger合并结果。这种很适合这样种场景:一部分数据在服务A,一部分数据在服务B,需要分别调用A和B,然后把两者的结果集合并设想着这样的方案:指定了合并策略,那么所有分组的invoker都会被调用到,那么请求就到FailoverClusterInvoker了,负载均衡spi就生效了修改一下负载均衡spi,如果目前调用的invoker不是指定分组的,那么就直接返回null实现自己的合并spi,返回第一个不会null的结果虽然不是什么优雅的方式,但是,似乎是能做到的???实际上,行不通,达不到想要的效果。原因是MergeableClusterInvoker内部是用线程池并发调用的,ThreadLocal里的分组信息会丢失。MergeableClusterInvoker类是没有留拓展的余地啦,还有其他机会么?MergeableClusterInvoker的Invokers列表从哪里来的?Invokers是从directory来的,这里有没有拓展的余地呢?有的,在AbstractDirectory的list方法看到这,发现用路由spi,还是有机会的,如果实现动态路由,每次只给MergeableClusterInvoker返回指定分组的Invoker,免费云主机域名是不是就可以呢?怎么让routers包含我们自定义的路由spi呢?需要url上携带了router参数,但是这里的url的参数是由谁决定的?@Reference 注解是没有没有的指定router参数的…最后debuig,兜兜转转,发现只能靠重写ReferenceConfig类的loadRegistries方法,往url上加上动态路由的参数。到此,相信大家对“dubbo怎么实现consumer从多个group中调用指定group的provider”有了更深的了解,不妨来实际操作一番吧!这里是百云主机网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

相关推荐: Android中如何实现放大镜效果

本文小编为大家详细介绍“Android中如何实现免费云主机域名放大镜效果”,内容详细,步骤清晰,细节处理妥当,希望这篇“Android中如何实现放大镜效果”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。源码分析基本原理就是使用Shap…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 05/26 11:37
Next 05/26 18:23

相关推荐