Dubbo(二)详细介绍

2023-10-29

转自:https://www.cnblogs.com/juncaoit/p/7686510.html

1.背景

  随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进。

 

2.架构

  单一应用架构 
    当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。 
    此时,用于简化增删改查工作量的 数据访问框架(ORM) 是关键。

  垂直应用架构 
    当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个应用,以提升效率。 
    此时,用于加速前端页面开发的 Web框架(MVC) 是关键。

  分布式服务架构 
    当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。 
    此时,用于提高业务复用及整合的 分布式服务框架(RPC) 是关键。

  流动计算架构 
    当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增加一个调度中心基于访问压力实时管理集群容量,提高集群利用率。 
    此时,用于提高机器利用率的 资源调度和治理中心(SOA) 是关键。

 

3.dubbox

  dubbox是dubbo的扩展,主要在dubbo的基础上进行了一下的改进  

  1、支持REST风格远程调用(HTTP + JSON/XML):基于非常成熟的JBoss RestEasy框架,在dubbo中实现了REST风格(HTTP + JSON/XML)的远程调用,以显著简化企业内部的跨语言交互,同时显著简化企业对外的Open API、无线API甚至AJAX服务端等等的开发。事实上,这个REST调用也使得Dubbo可以对当今特别流行的“微服务”架构提供基础性支持。 另外,REST调用也达到了比较高的性能,在基准测试下,HTTP + JSON与Dubbo 2.x默认的RPC协议(即TCP + Hessian2二进制序列化)之间只有1.5倍左右的差距,详见文档中的基准测试报告。

  2、支持基于Kryo和FST的Java高效序列化实现:基于当今比较知名的Kryo和FST高性能序列化库,为Dubbo默认的RPC协议添加新的序列化实现,并优化调整了其序列化体系,比较显著的提高了Dubbo RPC的性能,详见文档中的基准测试报告。

  3、支持基于Jackson的JSON序列化:基于业界应用最广泛的Jackson序列化库,为Dubbo默认的RPC协议添加新的JSON序列化实现。

  4、支持基于嵌入式Tomcat的HTTP remoting体系:基于嵌入式tomcat实现dubbo的HTTP remoting体系(即dubbo-remoting-http),用以逐步取代Dubbo中旧版本的嵌入式Jetty,可以显著的提高REST等的远程调用性能,并将Servlet API的支持从2.5升级到3.1。(注:除了REST,dubbo中的WebServices、Hessian、HTTP Invoker等协议都基于这个HTTP remoting体系)。

  5、升级Spring:将dubbo中Spring由2.x升级到目前最常用的3.x版本,减少版本冲突带来的麻烦。

  6、升级ZooKeeper客户端:将dubbo中的zookeeper客户端升级到最新的版本,以修正老版本中包含的bug。

  7、支持完全基于Java代码的Dubbo配置:基于Spring的Java Config,实现完全无XML的纯Java代码方式来配置dubbo

  8、调整Demo应用:暂时将dubbo的demo应用调整并改写以主要演示REST功能、Dubbo协议的新序列化方式、基于Java代码的Spring配置等等。 
  9、修正了dubbo的bug 包括配置、序列化、管理界面等等的bug。

 

4.Dubbo框架

  

  1、Provider:暴露服务的服务提供方。 Consumer: 调用远程服务的服务消费方。

  2、Registry:服务注册与发现的注册中心。 Monitor: 统计服务的调用次调和调用时间的监控中心。

  3、Container: 服务运行容器

 

5.Dubbo的调用关系

  1、服务容器负责启动,加载,运行服务提供者。 
  2、服务提供者在启动时,向注册中心注册自己提供的服务。 
  3、服务消费者在启动时,向注册中心订阅自己所需的服务。 
  4、注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。 
  5、服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。 
  6、服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。

 

6.Dubbo特点

  http://www.cnblogs.com/juncaoit/p/7567657.html

 

7.Dubbo调用方式

  • 异步调用

  基于NIO的非阻塞实现并行调用,客户端不需要启动多线程即可完成并行调用多个远程服务,相对多线程开销较小

  

  

  • 本地调用

  本地调用,使用了Injvm协议,是一个伪协议,它不开启端口,不发起远程调用,只在JVM内直接关联,但执行Dubbo的Filter链。

  Define injvm protocol:

    <dubbo:protocol name="injvm" />

  Set default protocol:

    <dubbo:provider protocol="injvm" />

  Set service protocol:

    <dubbo:service protocol="injvm" />

  Use injvm first:(服务暴露与服务引用都需要声明injvm=“true”)

  <dubbo:consumer injvm="true" .../>
  <dubbo:provider injvm="true" .../>
  或

  <dubbo:reference injvm="true" .../>
  <dubbo:service injvm="true" .../>

8.Dubbo支持的注册中心

  • Multicast注册中心
  • Zookeeper注册中心
  • Redis注册中心
  • Simple注册中心

  Multicast:不需要启动任何中心节点,只要广播地址一样,就可以互相发现

       组播受网络结构限制,只适合小规模应用或开发阶段使用。

       组播地址段: 224.0.0.0 - 239.255.255.255

  Zookeeper:是Apacahe Hadoop的子项目,是一个树型的目录服务,支持变更推送,适合作为Dubbo服务的注册中心,工业强度较高

        只需搭一个原生的Zookeeper服务器,

       并将Provider和Consumer里的dubbo.properties中的dubbo.registry.addrss的值改为zookeeper://127.0.0.1:2181即可使用
       阿里内部并没有采用Zookeeper做为注册中心,而是使用自己实现的基于数据库的注册中心,即:Zookeeper注册中心并没有在阿里
内部长时间运行的可靠性保障,其可靠性依赖于Zookeeper本身的可靠性。

       ZooKeeper集群由一组Server节点组成,这一组Server节点中存在一个角色为Leader的节点,其他节点都为Follower。当客户端Client连接到ZooKeeper集群,并且执行写请求时,这些请求会被发送到Leader节点上,然后Leader节点上数据变更会同步到集群中其他的Follower节点。

        

    流程说明:

    • 服务提供者启动时
      •   向/dubbo/com.foo.BarService/providers目录下写入自己的URL地址。
    • 服务消费者启动时
      •   订阅/dubbo/com.foo.BarService/providers目录下的提供者URL地址。
      •   并向/dubbo/com.foo.BarService/consumers目录下写入自己的URL地址。
    • 监控中心启动时
      •   订阅/dubbo/com.foo.BarService目录下的所有提供者和消费者URL地址。

    支持以下功能:

    •   当提供者出现断电等异常停机时,注册中心能自动删除提供者信息。
    •   当注册中心重启时,能自动恢复注册数据,以及订阅请求。
    •   当会话过期时,能自动恢复注册数据,以及订阅请求。
    •   当设置<dubbo:registry check="false" />时,记录失败注册和订阅请求,后台定时重试。
    •   可通过<dubbo:registry username="admin" password="1234" />设置zookeeper登录信息。
    •   可通过<dubbo:registry group="dubbo" />设置zookeeper的根节点,不设置将使用无根树。
    •   支持*号通配符<dubbo:reference group="*" version="*" />,可订阅服务的所有分组和所有版本的提供者

    在provider和consumer中增加zookeeper客户端jar包依赖

    支持zkclient和curator两种Zookeeper客户端实现

  Simple注册中心:

    注册中心本身就是一个普通的Dubbo服务,可以减少第三方依赖,使整体通讯方式一致。

  

9.Dubbo支持的远程通信协议

  • Mina
  • Netty
  • Grizzly

  

10.Dubbo支持的远程调用协议

  • Dubbo协议
  • Hessian协议
  • HTTP协议
  • RMI协议
  • WebService协议
  • Thrift协议
  • Memcached协议
  • Redis协议

  在通信过程中,不同的服务等级一般对应着不同的服务质量,那么选择合适的协议便是一件非常重要的事情。

 

11.Dubbo的容错

  在集群调用失败时,Dubbo提供了多种容错方案,缺省为failover重试。

    • Failover Cluster 
      失败自动切换,当出现失败,重试其它服务器。(缺省) 
      通常用于读操作,但重试会带来更长延迟。 
      可通过retries=“2”来设置重试次数(不含第一次)。

    • Failfast Cluster 
      快速失败,只发起一次调用,失败立即报错。 
      通常用于非幂等性的写操作,比如新增记录。

    • Failsafe Cluster 
      失败安全,出现异常时,直接忽略。 
      通常用于写入审计日志等操作。

    • Failback Cluster 
      失败自动恢复,后台记录失败请求,定时重发。 
      通常用于消息通知操作。

    • Forking Cluster 
      并行调用多个服务器,只要一个成功即返回。 
      通常用于实时性要求较高的读操作,但需要浪费更多服务资源。 
      可通过forks=“2”来设置最大并行数。

    • Broadcast Cluster 
      广播调用所有提供者,逐个调用,任意一台报错则报错。(2.1.0开始支持) 
      通常用于通知所有提供者更新缓存或日志等本地资源信息。

 

12.负载均衡

   

13.源码结构

  

  各个模块之间的关系:

  

  • dubbo-common 公共逻辑模块,包括Util类和通用模型。

  • dubbo-remoting 远程通讯模块,相当于Dubbo协议的实现,如果RPC用RMI协议则不需要使用此包。

  • dubbo-rpc 远程调用模块,抽象各种协议,以及动态代理,只包含一对一的调用,不关心集群的管理。

  • dubbo-cluster 集群模块,将多个服务提供方伪装为一个提供方,包括:负载均衡、容错、路由等,集群的地址列表可以是静态配置的,也可以是由注册中心下发。

  • dubbo-registry 注册中心模块,基于注册中心下发地址的集群方式,以及对各种注册中心的抽象。

  • dubbo-monitor 监控模块,统计服务调用次数,调用时间的,调用链跟踪的服务。

  • dubbo-config 配置模块,是Dubbo对外的API,用户通过Config使用Dubbo,隐藏Dubbo所有细节。

  • dubbo-container 容器模块,是一个Standalone的容器,以简单的Main加载Spring启动,因为服务通常不需要Tomcat/JBoss等Web容器的特性,没必要用Web容器去加载服务。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Dubbo(二)详细介绍 的相关文章

  • redis过期策略

    我们使用redis的时候一般会设置过期时间 redis设置过期时间 expire 只针对顶级key有效 即哈希结构不支持过期 value为hash结构的时候 不能对hash中的某一部分进行过期设置 expire key time 以秒为单位
  • PCL 环境下安装配置CGAL 5.5

    目录 一 CGAL简介 二 Using CGAL on Windows with Visual C 1 CGAL下载 2 GMP和MPRF安装 3 boost安装与环境变量设置 三 PCL环境下配置CGAL 四 测试代码 五 结果展示 一
  • 【机器学习】贝叶斯分类器(算法原理实现及sklearn实现)

    系列文章目录 第一章 先验概率和后验概率的通俗解释 贝叶斯分类 第二章 贝叶斯公式证明及Bayesain在机器学习重要地位的理解 第三章 机器学习 贝叶斯分类器 文章目录 系列文章目录 前沿 一 贝叶斯决策论 二 极大似然估计 三 朴素贝叶
  • ddt的使用

    ddt一指data driver test 是一种测试思想 意指数据驱动 这里将的ddt是ddt库 配合unittest使用 假设我们有个登录功能需要设计测试用例 用例如下 1 正确的账号密码登录 2 错误的账号密码登录 3 账号为空登录
  • 模拟电路设计(18)---负阻型正弦波振荡器

    负阻型正弦波振荡器 具有负的微变电阻特性的电子器件称为负阻器件 在一个LC或者谐振腔振荡回路中 若以负阻器件与消耗能量的常规电阻相抵消 使得振荡回路无能量消耗 那么电路也能维持正常的振荡 在实际电路中 负阻器件肯定是有源器件 由这种形式构成
  • Swagger 常用注解

    ApiOperation描述接口的详细内容 ApiModel描述实体类的相关信息 Api用在Controller上面说明Controller的信息 ApiModelProperty用在参数上说明参数的详细信息 ApiImplicitPara
  • 美团滑块模拟登录

    本教程仅限于学术探讨 也没有专门针对某个网站而编写 禁止用于非法用途 商业活动 恶意滥用技术等 否则后果自负 观看则同意此约定 如有侵权 请告知删除 谢谢 aHR0cHM6Ly9wYXNzcG9ydC5tZWl0dWFuLmNvbS9hY2
  • Chapter 17. Network Drivers

    17 Network Drivers Linux Device Drivers 3rd Edition Book Chapter 17 Network Drivers Having discussed char and block driv
  • InnoDB行锁等待

    关键词 InnoDB 行锁 行锁等待 行锁等待超时 问题 数据库错误 Lock wait timeout exceeded try restarting transaction 什么是锁等待 Lock Wait 呢 当事务A对数据表进行DD
  • Javaweb实验:静态网页制作

    Javaweb实验 1 静态网页制作 目录 Javaweb实验 前言 一 实验目的 二 实验原理 三 实验内容 四 实验步骤 五 实验结果 六 实验内容 七 实验步骤 八 实验结果 九 思考 1 frameset和frame标签的作用是什么
  • OpenGL错误总结

    const char getGLErrorInfo int errorId switch errorId case GL INVALID ENUM return GL Invalid Enum n case GL INVALID VALUE
  • python怎么实现检验_常用统计检验的Python实现

    前言 今天给大家整理了一些使用python进行常用统计检验的命令与说明 请注意 本文仅介绍如何使用python进行不同的统计检验 对于文中涉及的假设检验 统计量 p值 非参数检验 iid等统计学相关的专业名词以及检验背后的统计学意义不做讲解
  • Could not find OpenSSL. Install an OpenSSL development package or configure CMake with -DCMAKE_US

    安装cmake时 运行 configure 报错 CMake 3 17 0 rc2 Copyright 2000 2020 Kitware Inc and Contributors Found GNU toolchain C compile
  • transformer学习笔记

    文章目录 1 模型架构 1 1 seq2seq结构 1 2 注意力机制 2 transformer各部分介绍 2 1 encoder 2 1 1 encoder的输入 2 1 2 Multi head attention 2 1 3 lay
  • QML--学习第二篇

    QML的学习 一直找不到一个很好的参考资料 七零八落 找不到一个渐进的资料 希望自己学习的过程 给大家带来一些帮助 QML之组件 依然是main cpp 当然 没有main cpp 直接可以使用qmlviewer exe 直接打开 xml当
  • 什么会影响网站网页的打开速度

    如果打开速度慢 10个人会有9个人选择离开 我归纳了大约9大影响网站打开速度的因素 但网站页面显示的速度取决于众多的因素 包括服务器性能 网络传输质量 网站的带宽 DNS解析 网页内容包括涉及到的JS代码 图片和视频的大小等等各种因素 如有

随机推荐

  • 【pytorch】pytorch自定义训练vgg16和测试数据集 微调resnet18全连接层

    自己定义模型 测试 correct 0 total 0 for data in test loader img label data outputs net Variable img predict torch max outputs da
  • table的tr动态增加(含html示例)

    html页面table的tr动态增加 含示例 代码
  • 数据库原理(三):Sql Server操作语句

    文章目录 数据库 创建数据库 数据库表创建 删除数据库表 主键 外键 检查约束 7 2 插入数据 查询 9 1 2 查询不重复的信息 9 1 3 查询前五个 且显示固定列的数据 9 1 4 查询前百分之10 且显示所有列的数据 9 1 5
  • Redis 7 第五讲 事务、管道、发布订阅 过渡篇

    事务 理论 可以一次执行多个命令 本质是一组命令的集合 一个事务中的所有命令都会序列化 按顺序地串行化执行而不会被其它命令插入 不许加塞 一个队列中 一次性 顺序性 排他性的执行一系列命令 Redis事务 VS 关系型数据库事务 单独的隔离
  • Java中的this关键字

    只是总结一下 其实this主要要三种用法 表示对当前对象的引用 表示用类的成员变量 而非函数参数 注意在函数参数和成员变量同名是进行区分 其实这是第一种用法的特例 比较常用 所以那出来强调一下 用于在构造方法中引用满足指定参数类型的构造器
  • “网工”可以跳越“网管”吗?

    经常有读者问我 说 我刚毕业或者即将毕业 不想做网管 想直接成为一名网络设计 或者网络存储 网络安全工程师 可以吗 面对这样的提问 我不知道网友们是怎么考虑的 我个人的观点基本上还是要具体分析 不能一概而论 但总的来说 我建议 最好经历一个
  • Sqlilabs-14

    这里来到了第 14 关 题目是个忽悠 说是单引号 括号 整的跟 13 关一样但其实就是个大忽悠 在 Hackbar 上做注入 这一关 hackbar 又可以用了 这是属于哪波操作 uname admin passwd 111 submit
  • 【Apache Spark 】第 5 章Spark SQL 和 DataFrames:与外部数据源交互

    大家好 我是Sonhhxg 柒 希望你看完之后 能对你有所帮助 不足请指正 共同学习交流 个人主页 Sonhhxg 柒的博客 CSDN博客 欢迎各位 点赞 收藏 留言 系列专栏 机器学习 ML 自然语言处理 NLP 深度学习 DL fore
  • templateref html内容,angular之ng-template模板加载

    本文介绍了angular之ng template模板加载 分享给大家 具体如下 html5中的template template标签的含义 HTML 元素是一种用于保存客户端内容的机制 该内容在页面加载时是不可见的 但可以在运行时使用Jav
  • c++::用模板实现List

    我在用模板实现List的时候有很多奇奇怪怪的错误 以下我分享出来共勉 希望大家不要掉到和我一样的洞里 1 因为使用的是模板 所以在每个需要换类型的地方都换成模板参数T 我用的是T 读者可自己定义 2 赋值运算符的返回值和参数要带上
  • 解决:如何使Ubuntu中新窗口显示在屏幕中央?

    操作系统 Ubuntu 22 04LTS 问题描述 当打开一个新的窗口时 新窗口将出现在屏幕的左上角 解决方法 Ctrl Alt T打开终端 尝试一下该命令 gsettings set org gnome muter center new
  • 关于跨域调用的相关知识

    https github com colorhook crossdomain tree d97699e5e8d34f2bd91b565044c2de5a791c8bb7 JSONP原理及最简单的JSONP实现 http hi baidu c
  • byte为什么只能存储256个数字

    首先byte只占用1个字节 所以byte的取值范围使用二进制表示为 0000 0000 1111 1111 表示 127到 127 只有255个数字 但是有些地方说表示256个数字 因为这里0使用两种方式表示0000 0000和1000 0
  • 手机主域名服务器修复,手机主域名服务器修复

    手机主域名服务器修复 内容精选 换一换 安装依赖时 使用pip3 7 5 install xxx命令安装相关软件时提示无法连接网络 且提示 Could not find a version that satisfies the requir
  • SQL Server问题记录

    问题 DataGrip连接SQL Server 连接SQL Server失败 默认使用的驱动是sqljdbc4 结果报错信息如下 08S01 驱动程序无法通过使用安全套接字层 SSL 加密与 SQL Server 建立安全连接 错误 The
  • Zero Tier Windows远程桌面 免费跨网段 不在一个局域网 免费内网穿透

    1 注册 点击连接 ZeroTier Central 2 添加网络 点击 Create A Network 获取该网络network ID 下载 软件 https www zerotier com download 运行 右击右下角 图标
  • yolov5_prune剪枝训练记录及遇见的问题

    学习参考链接 转发 深度学习模型压缩与加速理论与实战 一 模型剪枝 AHU WangXiao 博客园 cnblogs com 剪枝顾名思义 就是通过一些算法或规则删去一些不重要的部分 来使模型变得更加紧凑 减小计算或者搜索的复杂度 它包括四
  • elasticsearch初识

    初识elasticsearch 了解ES elasticsearch的作用 elasticsearch是一款非常强大的开源搜索引擎 具备非常多强大功能 可以帮助我们从海量数据中快速找到需要的内容 例如 在GitHub搜索代码 在电商网站搜索
  • mysql没开启binlog恢复删除表_无全量备份、未开启binlog日志,利用percona工具恢复delete的数据...

    当我们忘记做全量备份时 并且没有开启binlog 并执行了delete from sbtest 数据全部丢失 要想恢复是很有难度的 今天 利用Percona Data Recovery Tool for InnoDB工具 仅支持InnoDB
  • Dubbo(二)详细介绍

    转自 https www cnblogs com juncaoit p 7686510 html 1 背景 随着互联网的发展 网站应用的规模不断扩大 常规的垂直应用架构已无法应对 分布式服务架构以及流动计算架构势在必行 亟需一个治理系统确保