Dubbo源码分析(一):概览
Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案,是阿里巴巴的一个开源项目。
笔者认为阿里巴巴的Dubbo的user guide写得非常好,下面是笔者摘抄的一部分内容:
随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进。
- 单一应用架构
- 当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。
- 此时,用于简化增删改查工作量的 数据访问框架(ORM) 是关键。
- 垂直应用架构
- 当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个应用,以提升效率。
- 此时,用于加速前端页面开发的 Web框架(MVC) 是关键。
- 分布式服务架构
- 当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。
- 此时,用于提高业务复用及整合的 分布式服务框架(RPC) 是关键。
- 流动计算架构
- 当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增加一个调度中心基于访问压力实时管理集群容量,提高集群利用率。
- 此时,用于提高机器利用率的 资源调度和治理中心(SOA) 是关键。
Dubbo的总体架构如下图所示:
节点角色说明:
- Provider: 暴露服务的服务提供方。
- Consumer: 调用远程服务的服务消费方。
- Registry: 服务注册与发现的注册中心。
- Monitor: 统计服务的调用次调和调用时间的监控中心。
- Container: 服务运行容器。
服务提供者需要注册服务,消费者通过注册中心获取服务描述,并利用这个描述找到服务进而调用服务完成功能。另外还有个观测者监控系统的运行。
Dubbo源码分析(一):概览相关推荐
- Retrofit源码分析一 概览
Retrofit源码分析一 概览 Retrofit的本质和与Okhttp的关系 说到Retrofit,免不了要提起Okhttp,因为二者通常是绑定到一起使用的.那么我们首先要明确一点Retrofi ...
- Dubbo 源码分析 - 集群容错之 LoadBalance
1.简介 LoadBalance 中文意思为负载均衡,它的职责是将网络请求,或者其他形式的负载"均摊"到不同的机器上.避免集群中部分服务器压力过大,而另一些服务器比较空闲的情况.通 ...
- Dubbo 源码分析 - 集群容错之 Cluster
1.简介 为了避免单点故障,现在的应用至少会部署在两台服务器上.对于一些负载比较高的服务,会部署更多台服务器.这样,同一环境下的服务提供者数量会大于1.对于服务消费者来说,同一环境下出现了多个服务提供 ...
- Dubbo 源码分析 - 集群容错之 Router
1. 简介 上一篇文章分析了集群容错的第一部分 – 服务目录 Directory.服务目录在刷新 Invoker 列表的过程中,会通过 Router 进行服务路由.上一篇文章关于服务路由相关逻辑没有细 ...
- Dubbo 源码分析 - 服务导出
1.服务导出过程 本篇文章,我们来研究一下 Dubbo 导出服务的过程.Dubbo 服务导出过程始于 Spring 容器发布刷新事件,Dubbo 在接收到事件后,会立即执行服务导出逻辑.整个逻辑大致可 ...
- dubbo源码分析系列(1)扩展机制的实现
1 系列目录 dubbo源码分析系列(1)扩展机制的实现 dubbo源码分析系列(2)服务的发布 dubbo源码分析系列(3)服务的引用 dubbo源码分析系列(4)dubbo通信设计 2 SPI扩展 ...
- apache dubbo 源码分析系列汇总
Dubbo(读音[ˈdʌbəʊ])是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和 Spring框架无缝集成.后面捐献给了知名的开源社区 ...
- 精尽 Dubbo 源码分析 —— API 配置
1. 概述 Dubbo 的配置目前提供了四种配置方式:1. API 配置 2. 属性配置 3. XML 配置 4. 注解配置 2. 配置一览 我们来看看 dubbo-config-api 的项目结构, ...
- Dubbo源码分析:全集整理
文章目录 一.前言 二.目录 1. 源码篇 2. 衍生篇 一.前言 本文是Dubbo源码分析目录集整理,方便后续查找. 本文持续更新中.文章内容尚在修改中, 受限于个人能力和理解偏差,该系列文章部分内 ...
- dubbo源码分析7 之 服务本地暴露
在上一篇文章我们分析了一下 dubbo 在服务暴露发生了哪些事,今天我们就来分析一下整个服务暴露中的本地暴露.(PS:其实我感觉本地暴露蛮鸡肋的).本地暴露需要服务提供方与服务消费方在同一个 JVM. ...
最新文章
- Linux0.00内核为什么要自己设置0x80号陷阱门来调用write_char过程?
- 2013大数据全球技术峰会观后感
- sql2000导出mysql_如何将sql2000的数据库导入到mysql中?
- mysql常见问题记录
- c语言数组与指针编程源码,C语言编程(练习9:数组与指针)
- intellij idea 的常用有用快捷键
- 电压调整率和负载调整率 简单易懂
- 基于Proteus的51单片机仿真
- R语言混合效应(多水平/层次/嵌套)模型及贝叶斯实现
- 糖豆推荐系统第一期开发与评估报告
- 视觉十四讲第六章G2O实践出错后的解决方法
- 感谢贤心感谢layui
- CAD等分不显示等分点
- html 在线测试 鱼缸,研究员试图用AR鱼缸欺骗鱼的感官系统,结果反被鱼识破
- 十首中国现代诗,很美!
- workitems in the coming 5 monthes.
- 微信小程序web-view与H5 通信方式探索
- mysql 日程设计_客服-电销日程表 - 数据库设计 - 数据库表结构 - 果创云
- 最小公倍数与最大公因数
- mysql errorcode 1366_mysql插入emoji表情报 error code [1366]
热门文章
- VIL100数据集处理
- 17计算机一级,全国计算机等级考试一级17
- 【云计算基础服务-Nginx WEB服务器---原理及简介详解】
- 微软MPP2.0 Microsoft Pen Protocol V2.0 officialEEAP.pdf
- Ansible批量管理Windows服务器,winrm配置
- 斐波那契数列编程C语言
- 解决eclipse: Resource is out of sync with the file system 报错问题
- @Value(“${}“)获取不到配置文件值的原因
- RPGMAKER游戏引擎基于JavaScript的插件制作(六)——重写方法(三):在场景(scenes)中创建精灵(Sprite)——复制式重写的实例教学
- Win10 下安装PhotoShop CS6