首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

dubbo源码分析二:服务发布(1)

dubbo源码分析二:服务发布(1)

本文将深入分析dubbo的服务发布涉及到的流程及主要类的代码。首先,我们先从类的关系图来看一下dubbo发布服务涉及到的相关类。1.类图

   上图展示了部分服务发布过程中需要使用到的类和接口,其中:
    spring适配涉及到的类:DubboNamespaceHandler、DubboBeanDefinitionParser、ServiceBean;
    配置信息存储:ServicdConfig、RegistryConfig、MonitorConfig、ProtocolConfig、ProviderConfig等;
    应用协议:Protocol、DubboProtocol、HessianProtocol、ThriftProtocol、RmiProtocol、AbstractProxyProtocol、AbstractProtocol等;
    Server相关:Exchanger、HeaderExchanger、ExchangeServer、HeaderExchangeServer、Transporters、Transporter、NettyTransporter、NettyServer等;

2.时序图
    我们通过时序图来分析一下在发布服务的过程中,上面的类是如何串联在一起的:
    a.spring容器通过DubboBeanDefinitionParser类的对象来解析xml文件中的标签,生成ServiceConfig等配置对象;
    b.ServiceConfig的export()等发布服务的方法被调用;
    c.通过spi机制确定Protocol接口的实现对象为DubboProtocol的对象,调用它的openServer()等方法;
    d.通过spi机制确定Transporter接口的实现对象为NettyTransporter,调用它的bind()方法;
    e.调用NettyServer类,启动netty服务,绑定端口。
返回列表