本节介绍dubbo-common,dubbo-common是公共逻辑模块,包含Util类、通用模型,是其他模块的基础。

扩展机制

SPI

SPI是扩展点的注解。标注在类型上。全部的扩展点须要通过SPI来标注。

约定:

在扩展类的jar包内。放置扩展点配置文件:META-INF/dubbo/接口全限定名,内容为:配置名=扩展实现类全限定名,多个实现类用换行符分隔。

1)        自己主动Wrap扩展点的Wrapper类

ExtensionLoader会在载入扩展点时(通过扩展点配置文件里内容)。假设该实现有拷贝构造函数。则判定为扩展点Wrapper类。

2)        自己主动注入关联扩展点

载入扩展点时,扩展点实现类的成员假设为其他扩展点类型,ExtensionLoader在会自己主动注入依赖的扩展点。

3)        缺省获得的的扩展点是一个Adaptive Instance

假设ExtensionLoader注入的依赖扩展点是一个Adaptive实例,直到扩展点方法运行时才决定调用是一个扩展点实现。

Adaptive

实现扩展点的自适应,能够标注在类型和方法上。在ExtensionLoader生成Extension的Adaptive Instance时。为ExtensionLoader提供扩展点信息。

以下是Dubbo的Transporter扩展点的代码:

@SPI("netty")

publicinterfaceTransporter{

/**

* Bind a server.

*

* @seecom.alibaba.dubbo.remoting.Transporters#bind(URL, Receiver, ChannelHandler)

* @param url serverurl

* @param handler

* @return server

* @throws RemotingException

*/

@Adaptive({Constants.SERVER_KEY, Constants.TRANSPORTER_KEY})

Server bind(URL url, ChannelHandlerhandler)throws RemotingException;

/**

* Connect to a server.

*

* @seecom.alibaba.dubbo.remoting.Transporters#connect(URL, Receiver, ChannelListener)

* @param url serverurl

* @param handler

* @return client

* @throws RemotingException

*/

@Adaptive({Constants.CLIENT_KEY, Constants.TRANSPORTER_KEY})

Client connect(URL url, ChannelHandlerhandler)throws RemotingException;

}

对于bind方法,Adaptive实现先查找"server"key,假设该Key没有值则找"transport"key值。来决定代理到哪个实际扩展点。

ExtensionFactory

ExtensionFactory本身也是一种SPI。属于扩展点本身的载入容器,可从不同容器载入扩展点。

当中AdaptiveExtensionFactory标注为Adaptive,支持扩展点的自己主动激活。当例如以下所看到的没有參数时。属于无条件自己主动激活。

@Adaptive

publicclass AdaptiveExtensionFactoryimplementsExtensionFactory

当有參数时,为有条件激活。

Logger

Logger也是一种扩展。

当中LoggerAdapter适配接口是一种SPI。

在Dubbo中,实现了JCL、JDK、Log4J和Slf4J的多种实现。

例如以下图所看到的我们经常使用的两种。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2lsYmVydHpob3U=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

ThreadPool

ThreadPool也是一种扩展SPI。

服务提供方线程实现策略。当server收到一个请求时。须要在线程池中创建一个线程去运行服务提供方业务逻辑。

@SPI("fixed")

publicinterfaceThreadPool{

/**

*
线程池

*

* @param url线程參数

* @return线程池

*/

@Adaptive({Constants.THREADPOOL_KEY})

Executor getExecutor(URL url);

}

如上SPI的參数作为默认的线程池类型,getExecutor方法中,通过"threadpool"的key来做到自适应扩展。

在Dubbo中实现了Fixed、Cached和Limited多种线程池的实现。

Serialize

Serialize是这里的核心接口。将对象转成字节流。用于网络传输,以及将字节流转为对象,用于在收到字节流数据后还原成对象。

下图是Dubbo中定义的接口。

下图是Dubbo中定义的扩展实现。各自是:

  • NativeJavaSerialization:原生java序列化实现。
  • CompactedJavaSerialization:压缩java序列化,主要是在原生java序列化基础上,实现了自己定义的类描写叙述符写入和读取。写Object类型的类描写叙述符仅仅写入类名称,而不是类的完整信息。这样有非常多Object类型的情况下能够降低序列化后的size。
  • JavaSerialization:仅仅是对原生java序列化和压缩java序列化的封装。

  • JsonSerialization:原生JSON序列化实现。

  • FastJsonSerialization:使用阿里的FastJson实现的序列化。
  • Hessian2Serialization:使用Hessian2的IO机制实现的序列化。

  • DubboSerialization:Dubbo自己定义的序列化实现。

Compiler

Compiler是SPI。Java代码编译器。用于动态生成字节码,加速调用。

实现了JDK和Javassist的实现。当中使用的Javassist是一个开源的分析、编辑和创建Java字节码的类库。Javassist是JBoss的一个子项目,其基本的长处,在于简单。并且高速。

Dubbo服务框架解析(二)的更多相关文章

  1. 当当网开源Dubbox,扩展Dubbo服务框架支持REST风格远程调用

    当当网近日开源了Dubbox项目,可为Dubbo服务框架提供多项扩展功能,包括REST风格远程调用.Kryo/FST序列化等等. 当当网架构部和技术委员会架构师沈理向InfoQ中文站介绍了Dubbox ...

  2. Dubbo服务框架和spring-cloud架构的优缺点

    Dubbo一.dubbo简介 Dubbo是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的RPC实现服务的输出和输入功能,可以和Spring框架无缝集成. Dubbo是一款高性能.轻 ...

  3. Volley 框架解析(二)--RequestQueue核心解读

    主要围绕RequestQueue进行解读,它的两个请求队列CacheQueue.NetworkQueue是如何调用的,第一条请求的执行过程及如何处理重复请求?对RequestQueue及相关的类进行详 ...

  4. 微服务框架学习二:Http调用

    1. HTTP接口的意义 二进制接口使用的是java/hessian序列化协议,不能很好的与其他语言通信,虽然hessian也是一种跨语言的通用协议,但很多语言没有很好的实现该协议的产品.所以为了能够 ...

  5. dubbo服务框架学习

    ====================================================================================== 1.提供注册服务.消费者可 ...

  6. 【转】阿里巴巴分布式服务框架 Dubbo 团队成员梁飞专访

    原文链接:http://www.iteye.com/magazines/103   Dubbo是阿里巴巴内部的SOA服务化治理方案的核心框架,每天为2000+ 个服务提供3,000,000,000+ ...

  7. 高性能的分布式服务框架 Dubbo

    我思故我在,提问启迪思考! 1. 什么是Dubbo? 官网:http://dubbo.io/,DUBBO是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及作为SOA服务治理的 ...

  8. RPC服务框架dubbo(一):简介和原理解析

    前置概念 在学习dubbo前,需要先了解SOA和RPC这两个概念. SOA 1.英文名称(Service Oriented Ambiguity) 2.中文名称:面向服务架构 2.1 有一个专门提供服务 ...

  9. 基于开源Dubbo分布式RPC服务框架的部署整合

    一.前言 Dubbo 作为SOA服务化治理方案的核心框架,用于提高业务逻辑的复用.整合.集中管理,具有极高的可靠性(HA)和伸缩性,被应用于阿里巴巴各成员站点,同时在包括JD.当当在内的众多互联网项目 ...

随机推荐

  1. 洛谷 P1416 攻击火星

    P1416 攻击火星 题目描述 一群外星人将要攻击火星. 火星的地图是一个n个点的无向图.这伙外星人将按照如下方法入侵,先攻击度为0的点(相当于从图中删除掉它),然后是度为1的点,依此类推直到度为n- ...

  2. ProgressBar-style属性分析

    首先我们看下framework下关于进度条的style定义,如下 <style name="Widget.ProgressBar"> <item name=&qu ...

  3. 4. Vue-Resource / axios 异步插件

    安装 cnmp i vue-resource --save (--save 安装到dependencies下) 引用 <script src="node_modules/vue-res ...

  4. Docker---(2)为什么要用Docker

    原文:Docker---(2)为什么要用Docker 版权声明:欢迎转载,请标明出处,如有问题,欢迎指正!谢谢!微信:w1186355422 https://blog.csdn.net/weixin_ ...

  5. [D3] Animate with the General Update Pattern in D3 v4

    In D3, the General Update Pattern is the name given to what happens when a data join is followed by ...

  6. Spring Boot 热部署(转)

    Spring Boot 热部署 实际开发中,修改某个页面数据或逻辑功能都需要重启应用.这无形中降低了开发效率,所以使用热部署是十分必要的. 什么是热部署? 应用启动后会把编译好的Class文件加载的虚 ...

  7. error app/styles/components/iconfont.scss (Line 12: Invalid GBK character "\xE5")

    因为要用到iconfont,引入iconfont到sass文件后,出现编译sass文件错误,如下截图: 解决方法:在顶部设置编码格式 @charset "utf-8"; 编译成功!

  8. POJ 1679 The Unique 次最小生成树 MST

    http://poj.org/problem?id=1679 题目大意: 给你一些点,判断MST(最小生成树)是否唯一. 思路: 以前做过这题,不过写的是O(n^3)的,今天学了一招O(n^2)的,哈 ...

  9. 【Codeforces Round #435 (Div. 2) B】Mahmoud and Ehab and the bipartiteness

    [链接]h在这里写链接 [题意] 让你在一棵树上,加入尽可能多的边. 使得这棵树依然是一张二分图. [题解] 让每个节点的度数,都变成二分图的对方集合中的点的个数就好. [错的次数] 0 [反思] 在 ...

  10. java项目中VO和DTO以及Entity,各自是在什么情况下应用的

    j2ee中,经常提到几种对象(object),理解他们的含义有助于我们更好的理解面向对象的设计思维.     POJO(plain old java object):普通的java对象,有别于特殊的j ...