资讯专栏INFORMATION COLUMN

dubbo实现原理---源码分析

Nosee / 1528人阅读

摘要:将标签的各种子标签如,存到一个叫的中。内部中一定存在一个方法从中拿到解析器。生成来实现的以方法为例。该方法的一大部分都是在拆解。

DUBBO 加载
spring加载bean的时候,遇到dubbo的命名空间时,会调用DubboNamespaceHandler类。执行init方法。将dubbo标签的各种子标签如service,reference存到一个叫parsers的HashMap中。

DUBBO标签的解析
所有通过标签定义的bean 都会定义成BeanDefinition。并且存到BeanDefinitionMap中

service标签,provide标签,consumer标签的识别都是用if判断的。

现在有两个map。一个spring初始化产生的存有dubbo各种子标签类型对应的解析器的parsers另一个是存有解析到的beandefintion的beandefinitionMap。dubbo内部中一定存在一个方法从parsers中拿到解析器。然后通过这个解析器解析bean。存到beandefinitionmap中。但是我没找到
仅仅只是这样还不能实现rpc调用
dubbo底层是通过在ServiceConfig.export 或者ReferenceConfig.get 初始化时,将Bean对象转会为url格式,将所有Bean属性转成url的参数。 生成url来实现的
以ServiceConfig.export方法为例。由于if语句占据了大量篇幅,直接截图核心部分

以上是本地暴露 向注册中心暴露服务:
和上一种的区别:需要将服务的IP和端口一同暴露给注册中心。
ServiceConfig解析出的url格式为:registry://registry-host/com.alibaba.dubbo.registry.RegistryService?export=URL.encode(url)
引用服务,
主要是用ReferenceConfig.init()。

该方法的一大部分都是在拆解url。最终调用refer方法。得到invoker。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/69383.html

相关文章

  • Dubbo 源码分析20 Dubbo服务提供者、服务消费者并发度控制机制

    摘要:代码根据服务提供者和服务调用方法名,获取。代码根据服务提供者配置的最大并发度,创建该服务该方法对应的信号量对象。总结是控制消费端对单个服务提供者单个服务允许调用的最大并发度。 本文将详细分析< dubbo:service executes=/>与< dubbo:reference actives = />的实现机制,深入探...

    不知名网友 评论0 收藏0
  • 【推荐】最新200篇:技术文章整理

    摘要:作为面试官,我是如何甄别应聘者的包装程度语言和等其他语言的对比分析和主从复制的原理详解和持久化的原理是什么面试中经常被问到的持久化与恢复实现故障恢复自动化详解哨兵技术查漏补缺最易错过的技术要点大扫盲意外宕机不难解决,但你真的懂数据恢复吗每秒 作为面试官,我是如何甄别应聘者的包装程度Go语言和Java、python等其他语言的对比分析 Redis和MySQL Redis:主从复制的原理详...

    BicycleWarrior 评论0 收藏0
  • 【推荐】最新200篇:技术文章整理

    摘要:作为面试官,我是如何甄别应聘者的包装程度语言和等其他语言的对比分析和主从复制的原理详解和持久化的原理是什么面试中经常被问到的持久化与恢复实现故障恢复自动化详解哨兵技术查漏补缺最易错过的技术要点大扫盲意外宕机不难解决,但你真的懂数据恢复吗每秒 作为面试官,我是如何甄别应聘者的包装程度Go语言和Java、python等其他语言的对比分析 Redis和MySQL Redis:主从复制的原理详...

    tommego 评论0 收藏0

发表评论

0条评论

Nosee

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<