Dubbo简介及实例
2016-08-31 16:49
225 查看
节点角色说明:
Ø Provider: 暴露服务的服务提供方。
Ø Consumer: 调用远程服务的服务消费方。
Ø Registry: 服务注册与发现的注册中心。
Ø Monitor: 统计服务的调用次调和调用时间的监控中心。
Ø Container: 服务运行容器。
调用关系说明:
0. 服务容器负责启动,加载,运行服务提供者。
1. 服务提供者在启动时,向注册中心注册自己提供的服务。
2. 服务消费者在启动时,向注册中心订阅自己所需的服务。
3. 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
4. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
5. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。
注册中心(Registry)说明:
对于Dubbo架构中的控制中心及Registry,阿里提供了两种方案:Zookeeper和Redis。生产环境建议大家都使用Zookeeper,推荐理由是:
1. Dubbo的官网上写着,使用Dubbo-2.3.3及以上的版本,推荐使用Zookeeper注册中心。
2. Zookeeper是Apache Hadoop的子项目,强度相对较好,能够完全胜任生产环境的扮演稳定的角色。
3. Dubbo未对Zookeeper服务端做任何侵入修改,只需安装原生的Zookeeper服务器即可,所有注册中心逻辑适配都在调用Zookeeper客户端完成。
为了简单起见,这个实例中,我们没有使用Zookeeper注册中心暴露服务地址,而是使用外网的multicast广播注册中心暴露服务地址。这样我们可以快速的认识一下Dubbo的作用。
案例中,我们建立了两个WebProject:dubboprovider和dubboconsumer,前者为服务提供方,后者作为客户端。我们将dubboprovider服务类的接口引入到dubboconsumer项目中(不能引用服务的实现类),然后通过multicast广播注册中心(真实环境用Registry)来远程调用dubboprovider服务的实现,如果能成功调到,就算成功。(项目中applicationContext.xml会报错,是由http://code.alibabatech.com/schema/dubbo/dubbo.xsd引起,说是阿里的相关服务换地方了,不过没关系,可以正常运行)
Ø Provider: 暴露服务的服务提供方。
Ø Consumer: 调用远程服务的服务消费方。
Ø Registry: 服务注册与发现的注册中心。
Ø Monitor: 统计服务的调用次调和调用时间的监控中心。
Ø Container: 服务运行容器。
调用关系说明:
0. 服务容器负责启动,加载,运行服务提供者。
1. 服务提供者在启动时,向注册中心注册自己提供的服务。
2. 服务消费者在启动时,向注册中心订阅自己所需的服务。
3. 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
4. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
5. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。
注册中心(Registry)说明:
对于Dubbo架构中的控制中心及Registry,阿里提供了两种方案:Zookeeper和Redis。生产环境建议大家都使用Zookeeper,推荐理由是:
1. Dubbo的官网上写着,使用Dubbo-2.3.3及以上的版本,推荐使用Zookeeper注册中心。
2. Zookeeper是Apache Hadoop的子项目,强度相对较好,能够完全胜任生产环境的扮演稳定的角色。
3. Dubbo未对Zookeeper服务端做任何侵入修改,只需安装原生的Zookeeper服务器即可,所有注册中心逻辑适配都在调用Zookeeper客户端完成。
3、实例
下面将不贴出来源码,只对项目结构即部分核心代码进行简单说明。源码自行下载,下载地址:点击打开链接为了简单起见,这个实例中,我们没有使用Zookeeper注册中心暴露服务地址,而是使用外网的multicast广播注册中心暴露服务地址。这样我们可以快速的认识一下Dubbo的作用。
案例中,我们建立了两个WebProject:dubboprovider和dubboconsumer,前者为服务提供方,后者作为客户端。我们将dubboprovider服务类的接口引入到dubboconsumer项目中(不能引用服务的实现类),然后通过multicast广播注册中心(真实环境用Registry)来远程调用dubboprovider服务的实现,如果能成功调到,就算成功。(项目中applicationContext.xml会报错,是由http://code.alibabatech.com/schema/dubbo/dubbo.xsd引起,说是阿里的相关服务换地方了,不过没关系,可以正常运行)
相关文章推荐
- ndk系列——使用新版Android Studio创建ndk项目
- 我的第一个网站(一)
- 深度剖析:如何实现一个 Virtual DOM 算法
- iOS-收集的不常用却实用的小方法和技巧
- 曲线平滑-B样条曲线
- Linux下网络流量实时监控工具大全
- 各种数据库连接URL关键代码
- LeetCode candy
- 经典面试题之字符串的全排列
- 解决win10系统flash player无法播放,升级
- Android之NestedScrollView 嵌套 RecyclerView 滑动冲突的问题
- PCI/PCIe那些事(3)-- Configuration Space Type 0/1
- 【C/C++】判断一个数是不是闰年
- 【如何正确使用const,static,extern】|那些人追的干货
- MLP多层感知机原理简介+代码详解
- Matlab计算机视觉/图像处理工具箱推荐
- ArcGIS 点的显示和隐藏、地图事件绑定
- [置顶] ubuntu12.04下编译vlc开源库
- Extjs4 封装echarts组件 2016.8.31
- 【基础学习】Android vector xml 将SVG转换成VectorDrawable 资源