1,背景

 
 
1,网站刚开时候的时候可能所有的功能业务都在一个应用里面
2,当业务不断复杂,流量不断增多的时候,就需要将原先的一个应用划分成多个独立的应用。
3,当分出来的业务越来越多的时候,应用也变的多而复杂,各个应用之间的交互也必不可少,就需要进行远程服务调用RPC,使用哪个找哪个,调用哪个。
4,当服务越来越多的时候,上面那种用一个找一个的方法,不仅管理混乱而且资源浪费,这时就需要一个服务调度中心来管理所有的服务信息,做为一个服务中心,所有使用者都只要关注服务中心即可。并且还需要不同服务 不同集群不同路由不同容错等等资源合理 运用起来才行。
而dubbo正好解决这样的一系列问题。
 

2,dubbo大体的架构

我的理解

dubbo大体上就是有三个部分,服务提供者,服务消费者,监控中心。服务提供者开发好服务之后,将调用这个服务的地址等信息都注册到一个服务注册中心去(常用zookeeper),通一个服务可以有多个提供者,服务消费者要消费的时候,就从注册中心拿过来自己要消费的服务的多个地址列表(有多个提供者的话),然后按照dobbo自己的软负载均衡算法,来选出一个提供者,去调用。这样,消费者不用去关心谁提供的服务,只需要找服务注册中心即可,而提供者也不需要将配置文件告诉所有消费者,只需要注册到注册中心即可。并且服务的集群负载均衡都是在消费端的,也保证了服务的干净,随时都可以增加减少服务提供者。

官方文字

 

节点角色说明:
Provider: 暴露服务的服务提供方。
Consumer: 调用远程服务的服务消费方。
Registry: 服务注册与发现的注册中心。
Monitor: 统计服务的调用次调和调用时间的监控中心。
Container: 服务运行容器。

调用关系说明:
0. 服务容器负责启动,加载,运行服务提供者。
1. 服务提供者在启动时,向注册中心注册自己提供的服务。
2. 服务消费者在启动时,向注册中心订阅自己所需的服务。
3. 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
4. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。

5. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。
 

dubbo的多样化方式

1,支持协议多样化

不同的服务,不同的场景,不同的消费者,可能适合的服务协议不一样,这里,dubbo已经实现了多种协议的提供和调用
     dubbo协议:使用mina,netty,grizzy三种之一来实现。
        rmi协议:使用jdk标准的java.rmi.*来实现
        hessian协议:采用Servlet暴露服务,Dubbo缺省内嵌Jetty作为服务器实现。
        http协议:采用Spring的HttpInvoker实现
        webservice协议:基于apache的cxf来实现
        thrift协议,memcached协议,redis协议     
并且dubbo也支持协议的扩展。
 

2,注册中心多样化

注册中心也实现了多种方式
Multicast注册中心:不需要启动任何中心节点,只要广播地址一样,就可以互相发现,但是组播受网络结构限制,只适合小规模应用或开发阶段使用。
Zookeeper注册中心:Zookeeper是Apacahe Hadoop的子项目,是一个树型的目录服务,支持变更推送,适合作为Dubbo服务的注册中心,工业强度较高,可用于生产环境,并推荐使用
Redis注册中心
Simple注册中心
 

3,dubbo也支持各种扩展

1,协议的扩展,可以根据自己的业务需求来扩展对应的协议,不过一般上也够用, 
2,负载均衡的扩展,如果觉得dubbo的集中负载均衡不够的话,可以自己扩展。
3,注册中心扩展,一般上用zookeeper也行了。
4,序列化的扩展,dubbo默认使用的是 hessian2(阿里修改了下)序列化方法,可扩展成kryo等更高效的。
等等
 
由此来说,dubbo的实现已经可以满足服务集中化管理的多种场景了。可以学学。
 
dubbo的具体使用方法细节参考:http://dubbo.io/Home-zh.htm  写的非常详细。

最新文章

  1. 部署 OpenStack VirtualBox
  2. java播放背景音乐的几种方式
  3. 网页闯关游戏(riddle webgame)--游戏玩法和整体介绍
  4. Linux挂载磁盘
  5. c# Json Dictionary序列化和反序列化
  6. java 超经漂亮验证码
  7. HTML5+开发移动app-mui开发示例
  8. USB方向
  9. 我的MYSQL学习心得 mysql日志
  10. 关于IE,Chrome,Firefox浏览器的字符串拼接问题
  11. 5.分析内核中断运行过程,以及中断3大结构体:irq_desc、irq_chip、irqaction
  12. 通过VBA,当在EXCEL单元格中输入任意的日期格式时,都能自动转换为指定的标准格式的日期值
  13. UITouch - BNR
  14. DP擎天
  15. C语言中使用bool
  16. flex布局嵌套之高度自适应
  17. spring boot 集成Druid
  18. sudo中的 各类授权 名称包含的操作 权限命令?
  19. BOM之navigator对象和用户代理检测
  20. js中, match和exec方法的区别

热门文章

  1. uva 11825 巧妙地子集枚举方法
  2. 手机app后台初学
  3. hibernate validate验证框架中@NotEmpty、@NotbBank、@NotNull的区别
  4. CSS:Tutorial one
  5. http keep - alive 与 长连接
  6. Dockerfile 模版
  7. Compile For Cydia Submission Author: BigBoss Updated September 23, 2011
  8. 【解题报告】[动态规划] - PID90 / 未出现的子串
  9. C# 在类文件自动添加文件注释的方法
  10. LA2218 Triathlon