Dubbo 需求、架构、使用Demo
只是整理下方便自己记录
内容全部来自官网:http://dubbo.io/books/dubbo-user-book/preface/usage.html
一、需求
在大规模服务化之前,应用可能只是通过 RMI 或 Hessian 等工具,简单的暴露和引用远程服务,通过配置服务的URL地址进行调用,通过 F5 等硬件进行负载均衡。
当服务越来越多时,服务 URL 配置管理变得非常困难,F5 硬件负载均衡器的单点压力也越来越大。 此时需要一个服务注册中心,动态的注册和发现服务,使服务的位置透明。并通过在消费方获取服务提供方地址列表,实现软负载均衡和 Failover,降低对 F5 硬件负载均衡器的依赖,也能减少部分成本。
当进一步发展,服务间依赖关系变得错踪复杂,甚至分不清哪个应用要在哪个应用之前启动,架构师都不能完整的描述应用的架构关系。 这时,需要自动画出应用间的依赖关系图,以帮助架构师理清理关系。
接着,服务的调用量越来越大,服务的容量问题就暴露出来,这个服务需要多少机器支撑?什么时候该加机器? 为了解决这些问题,第一步,要将服务现在每天的调用量,响应时间,都统计出来,作为容量规划的参考指标。其次,要可以动态调整权重,在线上,将某台机器的权重一直加大,并在加大的过程中记录响应时间的变化,直到响应时间到达阀值,记录此时的访问量,再以此访问量乘以机器数反推总容量。
以上是 Dubbo 最基本的几个需求。
二、架构
节点角色说明
节点 | 角色说明 |
---|---|
Provider
|
暴露服务的服务提供方 |
Consumer
|
调用远程服务的服务消费方 |
Registry
|
服务注册与发现的注册中心 |
Monitor
|
统计服务的调用次数和调用时间的监控中心 |
Container
|
服务运行容器 |
调用关系说明
- 服务容器负责启动,加载,运行服务提供者。
- 服务提供者在启动时,向注册中心注册自己提供的服务。
- 服务消费者在启动时,向注册中心订阅自己所需的服务。
- 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
- 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
- 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。
Dubbo 架构具有以下几个特点,分别是连通性、健壮性、伸缩性、以及向未来架构的升级性。
连通性
- 注册中心负责服务地址的注册与查找,相当于目录服务,服务提供者和消费者只在启动时与注册中心交互,注册中心不转发请求,压力较小
- 监控中心负责统计各服务调用次数,调用时间等,统计先在内存汇总后每分钟一次发送到监控中心服务器,并以报表展示
- 服务提供者向注册中心注册其提供的服务,并汇报调用时间到监控中心,此时间不包含网络开销
- 服务消费者向注册中心获取服务提供者地址列表,并根据负载算法直接调用提供者,同时汇报调用时间到监控中心,此时间包含网络开销
- 注册中心,服务提供者,服务消费者三者之间均为长连接,监控中心除外
- 注册中心通过长连接感知服务提供者的存在,服务提供者宕机,注册中心将立即推送事件通知消费者
- 注册中心和监控中心全部宕机,不影响已运行的提供者和消费者,消费者在本地缓存了提供者列表
- 注册中心和监控中心都是可选的,服务消费者可以直连服务提供者
健状性
- 监控中心宕掉不影响使用,只是丢失部分采样数据
- 数据库宕掉后,注册中心仍能通过缓存提供服务列表查询,但不能注册新服务
- 注册中心对等集群,任意一台宕掉后,将自动切换到另一台
- 注册中心全部宕掉后,服务提供者和服务消费者仍能通过本地缓存通讯
- 服务提供者无状态,任意一台宕掉后,不影响使用
- 服务提供者全部宕掉后,服务消费者应用将无法使用,并无限次重连等待服务提供者恢复
伸缩性
- 注册中心为对等集群,可动态增加机器部署实例,所有客户端将自动发现新的注册中心
- 服务提供者无状态,可动态增加机器部署实例,注册中心将推送新的服务提供者信息给消费者
升级性
当服务集群规模进一步扩大,带动IT治理结构进一步升级,需要实现动态部署,进行流动计算,现有分布式服务架构不会带来阻力。下图是未来可能的一种架构:
节点角色说明
节点 | 角色说明 |
---|---|
Deployer
|
自动部署服务的本地代理 |
Repository
|
仓库用于存储服务应用发布包 |
Scheduler
|
调度中心基于访问压力自动增减服务提供者 |
Admin
|
统一管理控制台 |
Registry
|
服务注册与发现的注册中心 |
Monitor
|
统计服务的调用次数和调用时间的监控中心 |
三、用法
本地服务 Spring 配置
local.xml:
<bean id=“xxxService” class=“com.xxx.XxxServiceImpl” />
<bean id=“xxxAction” class=“com.xxx.XxxAction”><property name=“xxxService” ref=“xxxService” />
</bean>
远程服务 Spring 配置
在本地服务的基础上,只需做简单配置,即可完成远程化:
- 将上面的
local.xml
配置拆分成两份,将服务定义部分放在服务提供方remote-provider.xml
,将服务引用部分放在服务消费方remote-consumer.xml
。 - 并在提供方增加暴露服务配置
<dubbo:service>
,在消费方增加引用服务配置<dubbo:reference>
。
remote-provider.xml:
<!-- 和本地服务一样实现远程服务 -->
<bean id=“xxxService” class=“com.xxx.XxxServiceImpl” />
<!-- 增加暴露远程服务配置 -->
<dubbo:service interface=“com.xxx.XxxService” ref=“xxxService” />
remote-consumer.xml:
<!-- 增加引用远程服务配置 -->
<dubbo:reference id=“xxxService” interface=“com.xxx.XxxService” />
<!-- 和本地服务一样使用远程服务 -->
<bean id=“xxxAction” class=“com.xxx.XxxAction”> <property name=“xxxService” ref=“xxxService” />
</bean>
在我们工程的实际使用中,注册中心用的是zookeeper,只用安装并服务处于启动状态就可以了。
并且服务的提供方和消费方在配置文件provider、consumer中可以不用写<bean> 标签。直接只写<debbo>标签就可以了。
Dubbo 需求、架构、使用Demo相关推荐
- Dubbo的架构设计
文章目录 Dubbo的架构图 Dubbo的部署架构图 注册中心 元数据中心 配置中心 Dubbo是阿里巴巴在2012年开源的分布式服务治理框架,不仅是阿里巴巴在开源领域最出名的项目,也应该算称得上是国 ...
- 分布式系统架构实战demo:SSM+Dubbo
对于传统的单一构架,也就是打成的war或者ear包部署在同一个Web容器里的构架,它虽然开发.测试.部署简单,但随着业务的不断发展,维护成本增加,可扩展性差,而且一台Tomcat的并发数在500左右, ...
- 阿里分布式服务框架Dubbo的架构总结
Dubbo是Alibaba开源的分布式服务框架,它最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解耦合(或者最大限度地松耦合).从服务模型的角度来看,Dubbo采用的是一种非常简单的模 ...
- Dubbo学习总结(5)——Dubbo服务架构及服务治理过程演进
单一应用架构 当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本. 此时,用于简化增删改查工作量的 数据访问框架(ORM) 是关键. 垂直应用架构 当访问量逐渐增大,单 ...
- Dubbo 分布式系统架构入门
Dubbo 概述 什么是分布式系统 分布式系统是若干独立计算机的集合,这些计算机对于用户来说就像单个相关系统. 分布式系统(distributed system)是建立在网络之上的软件系统. 简单来说 ...
- 架构师技术文档:Redis+Nginx+Dubbo+Spring+架构师精选视频
最近花了很长的时间去搜罗整理Java核心技术好文,我把每个Java核心技术的优选文章都整理成了一个又一个的文档.今天就把这些东西分享给老铁们,也能为老铁们省去不少麻烦,想学什么技能了,遇到哪方面的问题 ...
- 架构师技术文档:Redis+Nginx+Dubbo+Spring+ 架构师精选视频
最近花了很长的时间去搜罗整理Java核心技术好文,我把每个Java核心技术的优选文章都整理成了一个又一个的文档.今天就把这些东西分享给老铁们,也能为老铁们省去不少麻烦,想学什么技能了,遇到哪方面的问题 ...
- dubbo详解及demo实例
一.dubbo例子1(简单示例) 二.dubbo例子2(检查依赖) 三.dubbo集群容错 四.负载均衡策略 五.线程模型 六.直连提供者 七.多注册中心 八.多版本 九.异步调用 十.结果缓存 十一 ...
- 在window平台运行Dubbo的一个小demo
1.下载zookeeper 下载3.4.10版本 http://mirrors.hust.edu.cn/apache/zookeeper/ 2.运行zookeeper conf目录下配置好zoo.cf ...
最新文章
- Python 技术篇 - 文件的读取和写入
- 用隐式反馈做推荐模型,你做对了吗
- Android 绿豆通讯录【 SQLite数据库(增删改查、展示数据) + ListView数据展示控件(展示所有数据) 】
- win8看不到win7局域网计算机名,实现Win7旗舰版与win8.1系统局域网里文件共享的设置方法【图】...
- 深井软岩巷道群支护技术与应用_深井软岩巷道深浅孔帷幕注浆技术
- Android学习之在Eclipse看源代码的技巧
- 第3章 用户(账户)管理
- MyBatis 解析运行原理
- mysql的repeat_mysql函数中使用repeat循环的例子
- ta leader是什么岗位_阿里专家:如何成为一名“值得跟”的Leader?
- keil git 编译文件_交叉编译链下的Makefile(STM32F4xx)
- HDU1175 连连看【DFS】
- java抛异常 代替返回_Java使用和C++类似的异常处理
- 结构方程模型_结构方程模型(Structural Equation Model, SEM) 三下
- 好用的飞书版固定资产管理系统
- 谷歌地图解析及ArcEngine加载谷歌地图方法
- 中国股票市场化整为零,然后聚沙成塔
- 翟菜花:汽车市场首度遇冷,下沉市场与二手车会是破冰利器吗?
- 【Python】Numpy生成等差数组
- 攻防世界-web-mfw
热门文章
- python文本进度条94页_Python学习笔记 | 实例4:文本进度条
- 算法 -克鲁斯卡尔算法
- 给不会调用C++STL库中二分函数lower_bound,upper_bound,binary_search同学的一些话!
- 【CodeForces - 987C 】Three displays (dp,最长上升子序列类问题,三元组问题)
- alert 回调_JavaScript中到底什么时候回调函数Callback
- hashmap value占用空间大小_【Java集合框架002】原理层面:HashMap全解析
- linux c 禁止对外通信,Linux C套接字:在recv调用时被阻止
- log nginx 客户端请求大小_nginx log记录请求响应时间
- mysql还是mdb2_mysql两种表存储结构myisam和innodb的性能比较测试
- leetcode176. 第二高的薪水(SQL)