只是整理下方便自己记录

内容全部来自官网:http://dubbo.io/books/dubbo-user-book/preface/usage.html

一、需求

在大规模服务化之前,应用可能只是通过 RMI 或 Hessian 等工具,简单的暴露和引用远程服务,通过配置服务的URL地址进行调用,通过 F5 等硬件进行负载均衡。

当服务越来越多时,服务 URL 配置管理变得非常困难,F5 硬件负载均衡器的单点压力也越来越大。 此时需要一个服务注册中心,动态的注册和发现服务,使服务的位置透明。并通过在消费方获取服务提供方地址列表,实现软负载均衡和 Failover,降低对 F5 硬件负载均衡器的依赖,也能减少部分成本。

当进一步发展,服务间依赖关系变得错踪复杂,甚至分不清哪个应用要在哪个应用之前启动,架构师都不能完整的描述应用的架构关系。 这时,需要自动画出应用间的依赖关系图,以帮助架构师理清理关系。

接着,服务的调用量越来越大,服务的容量问题就暴露出来,这个服务需要多少机器支撑?什么时候该加机器? 为了解决这些问题,第一步,要将服务现在每天的调用量,响应时间,都统计出来,作为容量规划的参考指标。其次,要可以动态调整权重,在线上,将某台机器的权重一直加大,并在加大的过程中记录响应时间的变化,直到响应时间到达阀值,记录此时的访问量,再以此访问量乘以机器数反推总容量。

以上是 Dubbo 最基本的几个需求。

二、架构

节点角色说明
节点 角色说明
Provider 暴露服务的服务提供方
Consumer 调用远程服务的服务消费方
Registry 服务注册与发现的注册中心
Monitor 统计服务的调用次数和调用时间的监控中心
Container 服务运行容器
调用关系说明
  1. 服务容器负责启动,加载,运行服务提供者。
  2. 服务提供者在启动时,向注册中心注册自己提供的服务。
  3. 服务消费者在启动时,向注册中心订阅自己所需的服务。
  4. 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
  5. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
  6. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。

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相关推荐

  1. Dubbo的架构设计

    文章目录 Dubbo的架构图 Dubbo的部署架构图 注册中心 元数据中心 配置中心 Dubbo是阿里巴巴在2012年开源的分布式服务治理框架,不仅是阿里巴巴在开源领域最出名的项目,也应该算称得上是国 ...

  2. 分布式系统架构实战demo:SSM+Dubbo

    对于传统的单一构架,也就是打成的war或者ear包部署在同一个Web容器里的构架,它虽然开发.测试.部署简单,但随着业务的不断发展,维护成本增加,可扩展性差,而且一台Tomcat的并发数在500左右, ...

  3. 阿里分布式服务框架Dubbo的架构总结

    Dubbo是Alibaba开源的分布式服务框架,它最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解耦合(或者最大限度地松耦合).从服务模型的角度来看,Dubbo采用的是一种非常简单的模 ...

  4. Dubbo学习总结(5)——Dubbo服务架构及服务治理过程演进

    单一应用架构 当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本.  此时,用于简化增删改查工作量的 数据访问框架(ORM) 是关键.  垂直应用架构  当访问量逐渐增大,单 ...

  5. Dubbo 分布式系统架构入门

    Dubbo 概述 什么是分布式系统 分布式系统是若干独立计算机的集合,这些计算机对于用户来说就像单个相关系统. 分布式系统(distributed system)是建立在网络之上的软件系统. 简单来说 ...

  6. 架构师技术文档:Redis+Nginx+Dubbo+Spring+架构师精选视频

    最近花了很长的时间去搜罗整理Java核心技术好文,我把每个Java核心技术的优选文章都整理成了一个又一个的文档.今天就把这些东西分享给老铁们,也能为老铁们省去不少麻烦,想学什么技能了,遇到哪方面的问题 ...

  7. 架构师技术文档:Redis+Nginx+Dubbo+Spring+ 架构师精选视频

    最近花了很长的时间去搜罗整理Java核心技术好文,我把每个Java核心技术的优选文章都整理成了一个又一个的文档.今天就把这些东西分享给老铁们,也能为老铁们省去不少麻烦,想学什么技能了,遇到哪方面的问题 ...

  8. dubbo详解及demo实例

    一.dubbo例子1(简单示例) 二.dubbo例子2(检查依赖) 三.dubbo集群容错 四.负载均衡策略 五.线程模型 六.直连提供者 七.多注册中心 八.多版本 九.异步调用 十.结果缓存 十一 ...

  9. 在window平台运行Dubbo的一个小demo

    1.下载zookeeper 下载3.4.10版本 http://mirrors.hust.edu.cn/apache/zookeeper/ 2.运行zookeeper conf目录下配置好zoo.cf ...

最新文章

  1. Python 技术篇 - 文件的读取和写入
  2. 用隐式反馈做推荐模型,你做对了吗
  3. Android 绿豆通讯录【 SQLite数据库(增删改查、展示数据) + ListView数据展示控件(展示所有数据) 】
  4. win8看不到win7局域网计算机名,实现Win7旗舰版与win8.1系统局域网里文件共享的设置方法【图】...
  5. 深井软岩巷道群支护技术与应用_深井软岩巷道深浅孔帷幕注浆技术
  6. Android学习之在Eclipse看源代码的技巧
  7. 第3章 用户(账户)管理
  8. MyBatis 解析运行原理
  9. mysql的repeat_mysql函数中使用repeat循环的例子
  10. ta leader是什么岗位_阿里专家:如何成为一名“值得跟”的Leader?
  11. keil git 编译文件_交叉编译链下的Makefile(STM32F4xx)
  12. HDU1175 连连看【DFS】
  13. java抛异常 代替返回_Java使用和C++类似的异常处理
  14. 结构方程模型_结构方程模型(Structural Equation Model, SEM) 三下
  15. 好用的飞书版固定资产管理系统
  16. 谷歌地图解析及ArcEngine加载谷歌地图方法
  17. 中国股票市场化整为零,然后聚沙成塔
  18. 翟菜花:汽车市场首度遇冷,下沉市场与二手车会是破冰利器吗?
  19. 【Python】Numpy生成等差数组
  20. 攻防世界-web-mfw

热门文章

  1. python文本进度条94页_Python学习笔记 | 实例4:文本进度条
  2. 算法 -克鲁斯卡尔算法
  3. 给不会调用C++STL库中二分函数lower_bound,upper_bound,binary_search同学的一些话!
  4. 【CodeForces - 987C 】Three displays (dp,最长上升子序列类问题,三元组问题)
  5. alert 回调_JavaScript中到底什么时候回调函数Callback
  6. hashmap value占用空间大小_【Java集合框架002】原理层面:HashMap全解析
  7. linux c 禁止对外通信,Linux C套接字:在recv调用时被阻止
  8. log nginx 客户端请求大小_nginx log记录请求响应时间
  9. mysql还是mdb2_mysql两种表存储结构myisam和innodb的性能比较测试
  10. leetcode176. 第二高的薪水(SQL)