博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Dubbo—Zookeeper的典型应用
阅读量:6670 次
发布时间:2019-06-25

本文共 908 字,大约阅读时间需要 3 分钟。

1.Zookeeper 作为 Hadoop 项目中的一个子项目,是 Hadoop 集群管理的一个必不可少的模块,它主要用来控制集群中的数据,如它管理 Hadoop 集群中的 NameNode,还有 Hbase 中 Master Election、Server 之间状态同步等。

Zoopkeeper 提供了一套很好的分布式集群管理的机制,就是它这种基于层次型的目录树的数据结构,并对树中的节点进行有效管理,从而可以设计出多种多样的分布式的数据管理模型。

 

2.Dubbo是Alibaba开源的分布式服务框架,它最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解耦合(或者最大限度地松耦合)。从服务模型的角度来看,Dubbo采用的是一种非常简单的模型,要么是提供方提供服务,要么是消费方消费服务,所以基于这一点可以抽象出服务提供方(Provider)和服务消费方(Consumer)两个角色。关于注册中心、协议支持、服务监控等内容。

 

下面看一下简单的处理流程(没有详细展开,深入的话推荐看http://shiyanjun.cn/archives/325.html):

我们一般写Web程序,会分为三层,Controller,Service和Dao,其中Controller主要用来进行转发,Service进行业务逻辑的处理,而Dao是用来进行数据库映射。单机处理很容易,可是涉及到阿里这样庞大的业务时,比如淘宝、天猫、阿里旅行、天猫国际等等,就会发现它们都会用到支付服务,这时候我们很自然把支付服务单独拿出来,部署到其他服务器上,为了庞大的业务以及防止宕机,会部署到集群上。通过Dubbo,上层的开发者在写Controller层的时候,只需要写类似于Spring的简单依赖注入,就通过RPC调用到远程的服务,而服务层开发者也只需要关注服务层的业务逻辑即可。具体过程是先访问Dubbo后台的核心组件(内部是Zookeeper),核心组件有两个作用:1.判断哪台主机有相应的服务。2.判断哪台主机空闲。即名称服务和动态的负载均衡,然后告知Controller,Controller就会到相应的主机调用支付服务。

转载地址:http://jqoxo.baihongyu.com/

你可能感兴趣的文章
给PLSQL插上飞翔的翅膀-PLSQL优化
查看>>
做事原则
查看>>
一个男人该有的气质
查看>>
HDU 1004 Let the Balloon Rise【STL<map>】
查看>>
『cs231n』卷积神经网络工程实践技巧_下
查看>>
Anaconda和Pycharm安装和配置教程
查看>>
Java千百问_05面向对象(006)_is-a,has-a,like-a是什么
查看>>
【Python】python更新数据库脚本两种方法
查看>>
linux进程同步机制_转
查看>>
PHP框架认识初步
查看>>
给 Android 初学者的 Gradle 知识普及
查看>>
分模块开发创建Action子模块——(九)
查看>>
基于Nginx实现一个自己的HTTP模块
查看>>
LeetCode(34)-Palindrome Number
查看>>
阅读《Android 从入门到精通》(24)——切换图片
查看>>
SimpleDateFormat线程不安全及解决的方法
查看>>
Unity---------Mesh理解
查看>>
hdu 1728 逃离迷宫 bfs记转向
查看>>
一分钟学会 ConstraintLayout 之从属性角度理解布局
查看>>
线程 Timer TimerTask 计时器 定时任务 MD
查看>>