Dubbo模块介绍
一、Dubbo 整体框架

Dubbo主要有:Config 配置层、Proxy服务代理层、Registry注册中心层、Cluster 路由层、Monitor监控层、Protocol远程调用层、Exchange信息交换层、Transport 网络传输层、Serialize数据序列化层几个模块构成。
二、Dubbo 的各个角色




如上图所示,一个抽象出来的基本框架,consumer和provider是框架中必然存在的,Registry做为全局配置信息管理模块,推荐生产环境使用Registry,可实时推送现存活的服务提供者,Monitor一般用于监控和统计RPC调用情况、成功率、失败率等情况,让开发及运维了解线上运行情况。
应用执行过程大致如下:
服务提供者启动,根据协议信息绑定到配置的IP和端口上,如果已有服务绑定过相同IP和端口的则跳过
注册服务信息至注册中心
客户端启动,根据接口和协议信息订阅注册中心中注册的服务,注册中心将存活的服务地址通知到客户端,当有服务信息变更时客户端可以通过定时通知得到变更信息
在客户端需要调用服务时,从内存中拿到上次通知的所有存活服务地址,根据路由信息和负载均衡机制选择最终调用的服务地址,发起调用
通过filter分别在客户端发送请求前和服务端接收请求后,通过异步记录一些需要的信息传递到monitor做监控或者统计
三、模块介绍
3.1 dubbo-config 配置层
作用:
负责所有dubbo相关的xml配置和注释配置转换为config对象 ( dubbo.xsd )
Api配置的对象类,用于生成对应的register,protocol等对象
核心类:
ServiceBean、ReferenceBean (对应<dubbo:service /> <dubbo:reference/>)
ProtocolConfig、RegisterConfig (<dubbo:protocol /> <dubbo:register />)
3.2 dubbo-rpc
Proxy 服务代理层
作用:
负责生成消费者的代理对象,以及服务提供方的Invoke
核心类:
ProxyFactory接口的2种实现 JdkProxyFactory JavassistProxyFactory
3.3 dubbo-registry
Registry注册中心层
作用:
负责服务注册与查询服务,以及注册服务的本地缓存
支持多种协议注册发现服务,例如redis、zookeeper、Multicast
核心类:
接口 RegistryFactory、Registry
AbstractRegistry 以及 ZookeeperRegistry、ZookeeperRegistryFactory
3.4 dubbo-cluster
Cluster 路由层
作用:
负责负载均衡的策略,以及失败策略
缺省设置:RandomLoadBalance,FailoverCluster
支持轮询、随机、一致性哈希等负载均衡策略
核心类:
接口 LoadBalance、Cluster
RandomLoadBalance以及 RoundRobinLoadBalance等
3.5 dubbo-monitor
Monitor监控层
作用:
RPC调用次数和调用时间监控
dubbo-simple 下面的dubbo-monitor-simple提供了简单的控制台
核心类:
核心类DubboMonitor、Statistics
3.6 dubbo-rpc
Protocol远程调用层
作用:
封将RPC调用、支持多种RPC协议,不包含IO通信部分
支持RMI 、Hessian、Http、Webservice、thrift等rpc调用方式
核心类:
接口 Protocol Exporter Invoker
DubboProtocol、DubboInvoker、DubboExporter、DubboCodec
3.7 dubbo-remoting
Exchange信息交换层
作用:
封装请求响应模式,同步转异步
处理各种协议的通信请求,支持netty、mina、http等
默认采用Netty进行通信
核心类:
接口 Server、Channel、Client
NettyClient、NettyServer
3.8 dubbo-common
Serialize数据序列化层
作用:
数据序列化层和可复用的一些工具,包括序列化线程池等
dubbo协议缺省为hessian2,rmi协议缺省为java,http协议缺省为json
核心类:
接口 ThreadPool、Serialization
FixedThreadPool、 Hessian2Serialization
四、Dubbo使用方式:
4.1 Main函数的生产者和消费者
适用于纯后台服务集群
全部采用长连接
启动方式:com.alibaba.dubbo.container.Main
默认加载 META-INF/spring/*.xml
4.2 Java与Tomcat 生产者消费者
适用于大型web应用拆分服务
后台Main方法提供服务与tomcat Web应用消费者结合
用web.xml解析所有xml,加载dubbo
4.3 Xml 配置与代码配置
生产者
:
Xml : <dubbo:register/> Api: RegisterConfig
Xml : <dubbo:application/> Api: ApplicationConfig
Xml : <dubbo:protocol/> Api: ProtocolConfig
Xml : <dubbo:service/> Api: ServiceConfig
消费者
:
Xml : <dubbo:register/> Api: RegisterConfig
Xml : <dubbo:application/> Api: ApplicationConfig
Xml : <dubbo:reference/> Api: ReferenceConfig
Dubbo模块介绍的更多相关文章
- Dubbo入门介绍---搭建一个最简单的Demo框架
Dubbo入门---搭建一个最简单的Demo框架 置顶 2017年04月17日 19:10:44 是Guava不是瓜娃 阅读数:320947 标签: dubbozookeeper 更多 个人分类: D ...
- webkit模块介绍
一.Webkit模块 用到的第三方库如下: cairo 一个2D绘图库 casqt Unicode处理用的库,从QT中抽取部分代码形成的 expat 一个XML SAX解析器的库 freety ...
- 【液晶模块系列基础视频】1.2.iM_RGB模块介绍
[液晶模块系列基础视频]1.2.iM_RGB模块介绍(上) [液晶模块系列基础视频]1.2.iM_RGB模块介绍(下) ============================== 技术论坛:http ...
- 【液晶模块系列基础视频】1.1.iHMI43模块介绍
[液晶模块系列基础视频]1.1.iHMI43模块介绍(上) [液晶模块系列基础视频]1.1.iHMI43模块介绍(下) ============================== 技术论坛:http ...
- CSS3_概述、发展史、模块介绍、与浏览器之间的关系
一.CSS3概述和CSS3的发展史: 1.css3概述: CSS3是CSS2的升级版本,3只是版本号,它在CSS2.1的基础上增加了很多强大的新功能. 目前主流浏览器chrome.safari. ...
- 嵌入式系统图形库GUI核心模块介绍
本文转载自:http://blog.csdn.net/xteda/article/details/6575278 (作者 冯青华 信庭嵌入式工作室(www.xteda.com)- CEO Blog:h ...
- IIS7 常用模块介绍说明
1.1.0 IIS常用的功能模块介绍: 1) 静态内容:可发布静态 Web 文件格式,比如 HTML 页面和图像文件. 2) 默认文档:允许您配置当用户未在 URL ...
- python模块介绍- multi-mechanize 性能测试工具
python模块介绍- multi-mechanize 性能测试工具 2013-09-13 磁针石 #承接软件自动化实施与培训等gtalk:ouyangchongwu#gmail.comqq 3739 ...
- python模块介绍- xlwt 创建xls文件(excel)
python模块介绍- xlwt 创建xls文件(excel) 2013-06-24磁针石 #承接软件自动化实施与培训等gtalk:ouyangchongwu#gmail.comqq 37391319 ...
随机推荐
- jQuery 中让我误解的那些方法
至今我都不能说把 jQuery 中的方法在实践中都用了一遍, 一部分是用不到,一部分则是我未能体会它的魅力, 所以今天就来收录一下,那些从我们之间溜走的美丽. $.fn.add() 一开始对它的理解就 ...
- require.js和sea.js的区别
下面为大家讲解一下require.js和sea.js的区别.纯属个人意见,不喜勿喷. 首先原理上的区别 sea.js遵循CMD规范.书写方式类似node.js的书写模板代码.依赖的自动加载,配置的简洁 ...
- linux下查找文件或目录(which,whereis,locate,find)
命令 查找对象 查找速度 备注 which 可执行文件 根据PATH变量的内容去寻找可执行文件 不同的PATH配置会有不一样的结果 whereis 程序名的搜索 根据数据库来寻找,速度快 ...
- 基于Visual c++ 2012的php扩展开发 - 环境搭建
软件准备 Apache2.4 php-5.6.20-Win32-VC11-x86 php-5.6.20-src mysql-5.5.45-win32 vcredist_x86.exe vs2012旗舰 ...
- Ubuntu: 无法使用su命令
Ubuntu 无法使用su命令解决方案 在Ubuntu上编译Qt环境时发现无法使用su命令切换到root用户,通过网上查找发现解决方案如下: xt@xt-ubuntu:~$ su密码: su:认证失败 ...
- 关于Json如何转换成对象及获值问题!
var result = eval('('+result+')'); result为Json 转换成var result对象,可以 if(result.success){ window.locatio ...
- java进阶之-Maven,svn,git,maven合拼多个项目
git的使用介绍(写很容易懂得哦) maven合拼多个项目(写得很好哦) MAVEN作用:统一开发规范与工具:统一管理jar包 1.下载MAVEN 下载绿色版的面安装 2.环境配置 eclipse想 ...
- Kafka详解一:Kafka简介
问题导读 1.Kafka有何特性?2.Kafka有哪些组件? 背景: 当今社会各种应用系统诸如商业.社交.搜索.浏览等像信息工厂一样不断的生产出各种信息,在大数据时代,我们面临如下几个挑战: ...
- QT (QSS) 编程, QSS语法概述。。setstylesheet
http://www.cnblogs.com/davesla/archive/2011/01/30/1947928.html 转载] QT皮肤(QSS)编程 借用css 的灵感, Qt也支持Qt自己的 ...
- codeforces707A:Brain's Photos
Description Small, but very brave, mouse Brain was not accepted to summer school of young villains. ...