Dubbo的简单介绍

是什么?

Dubbo是阿里巴巴SOA服务化治理方案的核心框架,每天为2,000多个服务提供30多亿次訪问量支持。并被广泛应用于阿里巴巴集团的各成员网站。

Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案。以及SOA服务治理方案。

产生背景

(1)当服务越来越多时,服务URL配置管理变得很困难,F5硬件负载均衡器的单点压力也越来越大。

此时须要一个服务注冊中心,动态的注冊和发现服务,使服务的位置透明。

并通过在消费方获取服务提供方地址列表,实现软负载均衡和Failover。降低对F5硬件负载均衡器的依赖,也能降低部分成本。

(2)当进一步发展。服务间依赖关系变得错踪复杂,甚至分不清哪个应用要在哪个应用之前启动。架构师都不能完整的描写叙述应用的架构关系。

这时,须要自己主动画出应用间的依赖关系图,以帮助架构师理清理关系。

(3)接着,服务的调用量越来越大,服务的容量问题就暴露出来,这个服务须要多少机器支撑?什么时候该加机器?等等…

为了解决这些问题:

第一步,要将服务如今每天的调用量。响应时间。都统计出来,作为容量规划的參考指标。

其次,要能够动态调整权重,在线上,将某台机器的权重一直加大。并在加大的过程中记录响应时间的变化,直到响应时间到达阀值,记录此时的訪问量,再以此訪问量乘以机器数反推总容量。

核心部分:

远程通讯:提供对多种基于长连接的NIO框架抽象封装,包含多种线程模型。序列化。以及“请求-响应”模式的信息交换方式。

集群容错:提供基于接口方法的透明远程过程调用,包含多协议支持,以及软负载均衡,失败容错。地址路由。动态配置等集群支持。

自己主动发现:基于注冊中心文件夹服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方能够平滑添加或降低机器。

能做什么?

透明化的远程方法调用。就像调用本地方法一样调用远程方法。仅仅需简单配置,没有不论什么API侵入。

软负载均衡及容错机制。可在内网替代F5等硬件负载均衡器,降低成本。降低单点。

服务自己主动注冊与发现,不再须要写死服务提供方地址,注冊中心基于接口名查询服务提供者的IP地址,而且能够平滑加入或删除服务提供者。

架构图:

节点角色说明:

Provider: 暴露服务的服务提供方。

Consumer: 调用远程服务的服务消费方。

Registry: 服务注冊与发现的注冊中心。

Monitor:统计服务的调用次调和调用时间的监控中心。

Container: 服务执行容器。

调用关系说明:

0. 服务容器负责启动,载入。执行服务提供者。

1.服务提供者在启动时,向注冊中心注冊自己提供的服务。

2.服务消费者在启动时,向注冊中心订阅自己所需的服务。

3.注冊中心返回服务提供者地址列表给消费者,假设有变更,注冊中心将基于长连接推送变更数据给消费者。

4.服务消费者,从提供者地址列表中。基于软负载均衡算法,选一台提供者进行调用,假设调用失败。再选还有一台调用。

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

结束语:

下篇解说dubbo+zookeeper+spring的整合应用。zookeeper为注冊中心,接下来我们的学习主要结合基于zookeeper的Dubbo注冊中心来学习Dubbo这个分布式系统框架。

注:Dubbo的注冊中心有一下几种,用户指南中说明-推荐使用Zookeeper注冊中心

Dubbo用户指南:

用户指南

【Dubbo实战】基础学习篇(一)的更多相关文章

  1. 基于SOA分布式架构的dubbo框架基础学习篇

    以需求用例为基,抽象接口,Case&Coding两条线并行,服务(M)&消费(VC)分离,单元.接口.功能.集成四层质量管理,自动化集成.测试.交付全程支持. 3个大阶段(需求分析阶段 ...

  2. 鸟哥Linux私房菜基础学习篇学习笔记3

    鸟哥Linux私房菜基础学习篇学习笔记3 第十二章 正则表达式与文件格式化处理: 正则表达式(Regular Expression) 是通过一些特殊字符的排列,用以查找.删除.替换一行或多行文字字符: ...

  3. 鸟哥Linux私房菜基础学习篇学习笔记2

    鸟哥Linux私房菜基础学习篇学习笔记2 第九章 文件与文件系统的压缩打包: Linux下的扩展名没有什么特殊的意义,仅为了方便记忆. 压缩文件的扩展名一般为: *.tar, *.tar.gz, *. ...

  4. 鸟哥Linux私房菜基础学习篇学习笔记1

    鸟哥Linux私房菜基础学习篇学习笔记1 第三章 主导分区(MBR),当系统在开机的时候会主动去读取这个区块的内容,必须对硬盘进行分区,这样硬盘才能被有效地使用. 所谓的分区只是针对64Bytes的分 ...

  5. 拒绝从入门到放弃_《鸟哥的 Linux 私房菜 — 基础学习篇(第三版)》必读目录

    目录 目录 前言 关于这本书 必看知识点 最后 前言 相信部分刚进入这个行业的新同学会对一个问题感到疑惑,为什么从培训学校出来的学员不被欢迎? 这里记录下一些我个人的看法(博主也曾有面试新员工的经历) ...

  6. 【音视频连载-001】基础学习篇- SDL 介绍以及工程配置

    技术开发故事会连载 这是音视频基础学习系列的第一篇文章,主要讲解 SDL 是什么以及为什么要用到它,看似和音视频没啥卵关系,其实必不可少. SDL 简介 SDL 是 "Simple Dire ...

  7. Git 基础学习篇(应用-windows篇)

    此篇教程主要是讲应用,因为理论,,,额,我也说不出来.大家要深入学习还是看廖老师的教程吧. 可以把这篇当作一个简单应用的参考,因为当初看廖老师的也难看啊!!! 以下是资料: 廖雪峰-Git教程 [Gi ...

  8. Linux 基础学习篇 序篇

    读序篇可以知道的: 1.有些指令知道前和知道后,自己的操作是完全不同的,可能知道前,会用reset把系统重新启动一遍,而知道后会使用ps和kill来关闭进程. 2.如果对Linus的学习知识" ...

  9. JS基础学习篇(一)

    近来一直在学习js和jquery.刚刚进入前端工作还没有多久,虽然大学里学习的是编程自认为也学的还可以,但前端接触的不多,一直认为前端十分简单.其实不然,特别是工作的时候要自己设计一个完整的项目前端, ...

随机推荐

  1. php word转pdf

    我们知道,PHP语言的合理运用可以帮助我们实现导出Word文档的功能.今天我们将为大家介绍PHP处理Word转PDF的相关实现方法. PHP关键字this指向当前对象指针 PHP self关键字指向类 ...

  2. javascript设计模式-掺元类

    有一种重用代码的方法不需要用到严格的继承.如果想把一个函数用到多个类中,可以通过扩充的方式让这些类共享该函数.其实际做法大大体为:先创建一个包含各种通用方法的类,然后再用它扩充其他的类.这种方式就叫做 ...

  3. POJ3414 Pots

    题目: 给你两个容器,分别能装下A升水和B升水,并且可以进行以下操作 FILL(i)        将第i个容器从水龙头里装满(1 ≤ i ≤ 2); DROP(i)        将第i个容器抽干 ...

  4. 28. Implement strStr()[E]实现strStr()

    题目 Implement strStr(). Return the index of the first occurrence of needle in haystack, or -1 if need ...

  5. vim下的autocmd

    AUTOCMD *autocmd.txt* For Vim version 6.2. 最后修改: 2003年3月28日 VIM 参考手册 作者:Bram Moolenaar 翻译:Zimin<c ...

  6. C# 添加应用程序包

    项目中可能会遇到某些扩展方法不可以应用的情况,这时候需要在项目中引用程序包 步骤如下: 回车即可

  7. web拼图错误分析

    老师要求用web制作一个拼图游戏. 发现的问题:点击随机生成拼图的按钮后,打乱的图片会出现无法还原的情况. 发现过程:每次生成一个拼图后会测试它怎么拼回去,结果发现有时候拼不回去. 数学原理:如果两个 ...

  8. 第八周读书笔记(人月神话X月亮与六便士)——到底什么才是一个程序员的自我修养?

    写了这么久的读书笔记,涉及到问题大多是一些如何把软件工程做好,如何把自己的职业生涯做好.但总感觉逻辑链上缺了一环,亦即:我们为什么要把软件工程做好,我们成为一名优秀的职业生涯的意义到底在于什么?我觉得 ...

  9. 图像检索中为什么仍用BOW和LSH

    原文链接:http://blog.csdn.net/jwh_bupt/article/details/27713453 去年年底的时候在一篇博客中,用ANN的框架解释了BOW模型[1],并与LSH[2 ...

  10. python版本及ML库

    一:关于Python版本的选择问题 关于Python的选择问题:要看学术界能不能把科学库迁移到Python3. 1:多个版本共用: 最近发现SciPy的最高版本是3.2,只能是退而求其次,不使用最新版 ...