详解 | Dubbo 的 5 个分之和 3 大新特性-程序员宅基地

640?wx_fmt=png

Apache Dubbo Meetup · 南京站


本文是对 Apache Dubbo Meetup 南京站演讲嘉宾徐靖峰(花名:岛风)分享内容的回顾,首发于Kirito的技术分享,阿里巴巴中间件受权转载。



Dubbo 分支



Dubbo 目前有如图所示的 5 个分支,其中 2.7.1-release 只是一个临时分支,忽略不计,对其他 4 个分支进行介绍。



640?wx_fmt=other



  • 2.5.x 近期已经通过投票,Dubbo 社区即将停止对其的维护。

  • 2.6.x 为长期支持的版本,也是 Dubbo 贡献给 Apache 之前的版本,其包名前缀为:com.alibaba,JDK 版本对应 1.6。

  • 3.x-dev 是前瞻性的版本,对 Dubbo 进行一些高级特性的补充,如支持 rx 特性。

  • master 为长期支持的版本,版本号为 2.7.x,也是 Dubbo 贡献给 Apache 的开发版本,其包名前缀为:org.apache,JDK 版本对应 1.8。

如果想要研究 Dubbo 的源码,建议直接浏览 master 分支。


Dubbo 2.7 新特性



Dubbo 2.7.x 作为 Apache 的孵化版本,除了对代码进行优化之外,还新增了许多重磅的新特性,本文将介绍其中最典型的三个新特性:


  • 异步化改造

  • 三大中心改造

  • 服务治理增强



异步化改造



4 种调用方式

640?wx_fmt=png

在远程方法调用中,大致可以分为这 4 种调用方式。


oneway 指的是客户端发送消息后,不需要接受响应。对于那些不关心服务端响应的请求,比较适合使用 oneway 通信。

注意,void hello() 方法在远程方法调用中,不属于 oneway 调用,虽然 void 方法表达了不关心返回值的语义,但在 RPC 层面,仍然需要做通信层的响应。

sync 是最常用的通信方式,也是默认的通信方法。


future 和 callback 都属于异步调用的范畴,他们的区别是:在接收响应时,future.get() 会导致线程的阻塞;callback 通常会设置一个回调线程,当接收到响应时,自动执行,不会对当前线程造成阻塞。


Dubbo 2.6 异步化

异步化的优势在于,客户端不需要启动多线程即可完成并行调用多个远程服务,相比于多线程,异步化开销较小。


介绍 2.7 中的异步化改造之前,先回顾一下如何在 2.6 中使用 Dubbo 异步化的能力。

将同步接口声明成 async=true

<dubbo:reference id="asyncService" interface="org.apache.dubbo.demo.api.AsyncService" async="true"/>

public interface AsyncService {	
    String sayHello(String name);	
}


通过上下文类获取 future

AsyncService.sayHello("Han Meimei");	
Future<String> fooFuture = RpcContext.getContext().getFuture();	
fooFuture.get();


可以看出,这样的使用方式,不太符合异步编程的习惯,竟然需要从一个上下文类中获取到 Future。如果同时进行多个异步调用,使用不当很容易造成上下文污染。而且,Future 并不支持 callback 的调用方式。这些弊端在 Dubbo 2.7 中得到了改进。


Dubbo 2.7 异步化

无需配置中特殊声明,显示声明异步接口即可

public interface AsyncService {	
    String sayHello(String name);	
    default CompletableFuture<String> sayHiAsync(String name) {	
        return CompletableFuture.completedFuture(sayHello(name));	
    }	
}


使用 callback 方式处理返回值

CompletableFuture<String> future = asyncService.sayHiAsync("Han MeiMei");	
future.whenComplete((retValue, exception) -> {	
    if (exception == null) {	
        System.out.println(retValue);	
    } else {	
        exception.printStackTrace();	
    }	
});


Dubbo 2.7 中使用了 JDK1.8 提供的 CompletableFuture 原生接口对自身的异步化做了改进。 CompletableFuture 可以支持 future 和 callback 两种调用方式,用户可以根据自己的喜好和场景选择使用,非常灵活。


异步化设计 FAQ

Q:如果 RPC 接口只定义了同步接口,有办法使用异步调用吗?

A:2.6 中的异步调用唯一的优势在于,不需要在接口层面做改造,又可以进行异步调用,这种方式仍然在 2.7 中保留;使用 Dubbo 官方提供的 compiler hacker,编译期自动重写同步方法,请在此[1]讨论和跟进具体进展。


Q:关于异步接口的设计问题,为何不提供编译插件,根据原接口,自动编译出一个 XxxAsync 接口?

A:Dubbo 2.7 采用采用过这种设计,但接口的膨胀会导致服务类的增量发布,而且接口名的变化会影响服务治理的一些相关逻辑,改为方法添加 Async 后缀相对影响范围较小。


Q:Dubbo 分为了客户端异步和服务端异步,刚刚你介绍的是客户端异步,为什么不提服务端异步呢?

A:Dubbo 2.7 新增了服务端异步的支持,但实际上,Dubbo 的业务线程池模型,本身就可以理解为异步调用,个人认为服务端异步的特性较为鸡肋。



三大中心改造



三大中心指的:注册中心,元数据中心,配置中心。


在 2.7 之前的版本,Dubbo 只配备了注册中心,主流使用的注册中心为 ZooKeeper。新增加了元数据中心和配置中心,自然是为了解决对应的痛点,下面我们来详细阐释三大中心改造的原因。


元数据改造

元数据定义为描述数据的数据,在服务治理中,例如服务接口名、重试次数和版本号等等,都可以理解为元数据。在 2.7 之前,元数据一股脑丢在了注册中心,这造成了一系列的问题:


推送量大 -> 存储数据量大 -> 网络传输量大 -> 延迟严重


生产者端注册 30+ 参数,有接近一半是不需要作为注册中心进行传递的;消费者端注册 25+ 参数,只有个别需要传递给注册中心。


有了以上的理论分析,Dubbo 2.7 进行了大刀阔斧的改动,只将真正属于服务治理的数据发布到注册中心之中,大大降低了注册中心的负荷。


同时,将全量的元数据发布到另外的组件中:元数据中心。元数据中心目前支持 Redis(推荐),ZooKeeper。这也为 Dubbo 2.7 全新的 Dubbo Admin 做了准备,关于新版的 Dubbo Admin,我将会后续准备一篇独立的文章进行介绍。


示例:使用 ZooKeeper 作为元数据中心:

<dubbo:metadata-report address="zookeeper://127.0.0.1:2181"/>


Dubbo 2.6 元数据

dubbo://30.5.120.185:20880/com.alibaba.dubbo.demo.DemoService?	
anyhost=true&	
application=demo-provider&	
interface=com.alibaba.dubbo.demo.DemoService&	
methods=sayHello&	
bean.name=com.alibaba.dubbo.demo.DemoService&	
dubbo=2.0.2&	
executes=4500&	
generic=false&	
owner=kirito&	
pid=84228&	
retries=7&	
side=provider&	
timestamp=1552965771067


从本地的 ZooKeeper 中取出一条服务数据,通过解码之后,可以看出,的确有很多参数是不必要。


Dubbo 2.7 元数据

在 2.7 中,如果不进行额外的配置,ZooKeeper 中的数据格式仍然会和 Dubbo 2.6 保持一致,这主要是为了保证兼容性,让 Dubbo 2.6 的客户端可以调用 Dubbo 2.7 的服务端。如果整体迁移到 2.7,则可以为注册中心开启简化配置的参数:

<dubbo:registry address=“zookeeper://127.0.0.1:2181” simplified="true"/>


Dubbo 将会只上传那些必要的服务治理数据,一个简化过后的数据如下所示:

dubbo://30.5.120.185:20880/org.apache.dubbo.demo.api.DemoService?	
application=demo-provider&	
dubbo=2.0.2&	
release=2.7.0&	
timestamp=1552975501873


对于那些非必要的服务信息,仍然全量存储在元数据中心之中:

640?wx_fmt=jpeg

元数据中心的数据可以被用于服务测试,服务 MOCK 等功能。目前注册中心配置中 simplified 的默认值为 false,因为考虑到了迁移的兼容问题,在后续迭代中,默认值将会改为 true。


配置中心支持

衡量配置中心的必要性往往从三个角度出发:


  • 分布式配置统一管理

  • 动态变更推送

  • 安全性


Spring Cloud Config,Apollo,Nacos 等分布式配置中心组件都对上述功能有不同程度的支持。


在 2.7 之前的版本中,ZooKeeper 中设置了部分节点:configurators 和 routers,用于管理部分配置和路由信息,它们可以理解为 Dubbo 配置中心的雏形。在 2.7 中,Dubbo 正式支持了配置中心开源组件,目前支持的几种配置中心有:ZooKeeper,Apollo,Nacos(2.7.1-release 支持)。


在 Dubbo 中,配置中心主要承担了两个作用:


  • 外部化配置。启动配置的集中式存储;

  • 服务治理。服务治理规则的存储与通知;


示例:使用 ZooKeeper 作为配置中心

<dubbo:config-center address="zookeeper://127.0.0.1:2181"/>


引入配置中心后,需要注意配置项的覆盖问题,优先级如图所示:

640?wx_fmt=jpeg


服务治理增强



我更倾向于将 Dubbo 当做一个服务治理框架,而不仅仅是一个 RPC 框架。


在 2.7 中,Dubbo 对其服务治理能力进行了增强,增加了标签路由的能力,并抽象出了应用路由和服务路由的概念。在最后一个特性介绍中,着重对标签路由 TagRouter 进行探讨。

在服务治理中,路由层和负载均衡层的对比。区别 1,Router:m 选 n,LoadBalance:n 选 1;区别 2,路由往往是叠加使用的,负载均衡只能配置一种。


在很长的一段时间内,Dubbo 社区经常有人提的一个问题是:Dubbo 如何实现流量隔离和灰度发布,直到 2.7 提供了标签路由,用户可以使用这个功能,来实现上述的需求。

640?wx_fmt=png

标签路由提供了这样一个能力:当调用链路为 A -> B -> C -> D 时,用户给请求打标,最典型的打标方式可以借助 attachment(他可以在分布式调用中传递下去),调用会优先请求那些匹配的服务端,如 A -> B,C -> D,由于集群中未部署 C 节点,则会降级到普通节点。


打标方式会收到集成系统差异的影响,从而导致很大的差异,所以 Dubbo 只提供了 RpcContext.getContext().setAttachment() 这样的基础接口,用户可以使用 SPI 扩展,或者 server filter 的扩展,对测试流量进行打标,引导进入隔离环境/灰度环境。


新版的 Dubbo Admin 提供了标签路由的配置项:

640?wx_fmt=png

Dubbo 用户可以在自己系统的基础上对标签路由进行二次扩展,或者借鉴标签路由的设计,实现自己系统的流量隔离,灰度发布。



总结



本文介绍了 Dubbo 2.7 比较重要的三大新特性:异步化改造,三大中心改造,服务治理增强。此外,Dubbo 2.7 还包含了很多功能优化、特性升级,可以在项目源码的 CHANGES.md[2] 中浏览全部的改动点。最后,提供一份 Dubbo 2.7 的升级文档:2.7迁移文档[3],欢迎体验。


相关链接:

[1] compile hacker 

https://github.com/dubbo/dubbo-async-processor#compiler-hacker-processer

[2] CHANGES.md

https://github.com/apache/incubator-dubbo/blob/master/CHANGES.md

[3] 2.7迁移文档

http://dubbo.incubator.apache.org/zh-cn/docs/user/versions/version-270.html


本文作者:

徐靖峰(花名:岛风)

GitHub ID lexburner,阿里巴巴高级开发工程师,负责阿里巴巴服务治理框架的研发工作,关注微服务、服务治理和软件设计等领域。


文章缩略图

 Photo by Cody  Davis on Unsplash


/ Dubbo x 网易考拉? /


640?wx_fmt=jpeg


每周一推

第一时间获得下期分享


640?wx_fmt=gif

Tips:

# 点下“看”️

# 然后,公众号对话框内发送“Polo衫,试试手气??

# 本期奖品是 Aliware 定制 Polo衫

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_39860915/article/details/98863898

智能推荐

leetcode 172. 阶乘后的零-程序员宅基地

文章浏览阅读63次。题目给定一个整数 n,返回 n! 结果尾数中零的数量。解题思路每个0都是由2 * 5得来的,相当于要求n!分解成质因子后2 * 5的数目,由于n中2的数目肯定是要大于5的数目,所以我们只需要求出n!中5的数目。C++代码class Solution {public: int trailingZeroes(int n) { ...

Day15-【Java SE进阶】IO流(一):File、IO流概述、File文件对象的创建、字节输入输出流FileInputStream FileoutputStream、释放资源。_outputstream释放-程序员宅基地

文章浏览阅读992次,点赞27次,收藏15次。UTF-8是Unicode字符集的一种编码方案,采取可变长编码方案,共分四个长度区:1个字节,2个字节,3个字节,4个字节。文件字节输入流:每次读取多个字节到字节数组中去,返回读取的字节数量,读取完毕会返回-1。注意1:字符编码时使用的字符集,和解码时使用的字符集必须一致,否则会出现乱码。定义一个与文件一样大的字节数组,一次性读取完文件的全部字节。UTF-8字符集:汉字占3个字节,英文、数字占1个字节。GBK字符集:汉字占2个字节,英文、数字占1个字节。GBK规定:汉字的第一个字节的第一位必须是1。_outputstream释放

jeecgboot重新登录_jeecg 登录自动退出-程序员宅基地

文章浏览阅读1.8k次,点赞3次,收藏3次。解决jeecgboot每次登录进去都会弹出请重新登录问题,在utils文件下找到request.js文件注释这段代码即可_jeecg 登录自动退出

数据中心供配电系统负荷计算实例分析-程序员宅基地

文章浏览阅读3.4k次。我国目前普遍采用需要系数法和二项式系数法确定用电设备的负荷,其中需要系数法是国际上普遍采用的确定计算负荷的方法,最为简便;而二项式系数法在确定设备台数较少且各台设备容量差..._数据中心用电负荷统计变压器

HTML5期末大作业:网页制作代码 网站设计——人电影网站(5页) HTML+CSS+JavaScript 学生DW网页设计作业成品 dreamweaver作业静态HTML网页设计模板_网页设计成品百度网盘-程序员宅基地

文章浏览阅读7k次,点赞4次,收藏46次。HTML5期末大作业:网页制作代码 网站设计——人电影网站(5页) HTML+CSS+JavaScript 学生DW网页设计作业成品 dreamweaver作业静态HTML网页设计模板常见网页设计作业题材有 个人、 美食、 公司、 学校、 旅游、 电商、 宠物、 电器、 茶叶、 家居、 酒店、 舞蹈、 动漫、 明星、 服装、 体育、 化妆品、 物流、 环保、 书籍、 婚纱、 军事、 游戏、 节日、 戒烟、 电影、 摄影、 文化、 家乡、 鲜花、 礼品、 汽车、 其他 等网页设计题目, A+水平作业_网页设计成品百度网盘

【Jailhouse 文章】Look Mum, no VM Exits_jailhouse sr-iov-程序员宅基地

文章浏览阅读392次。jailhouse 文章翻译,Look Mum, no VM Exits!_jailhouse sr-iov

随便推点

chatgpt赋能python:Python怎么删除文件中的某一行_python 删除文件特定几行-程序员宅基地

文章浏览阅读751次。本文由chatgpt生成,文章没有在chatgpt生成的基础上进行任何的修改。以上只是chatgpt能力的冰山一角。作为通用的Aigc大模型,只是展现它原本的实力。对于颠覆工作方式的ChatGPT,应该选择拥抱而不是抗拒,未来属于“会用”AI的人。AI职场汇报智能办公文案写作效率提升教程 专注于AI+职场+办公方向。下图是课程的整体大纲下图是AI职场汇报智能办公文案写作效率提升教程中用到的ai工具。_python 删除文件特定几行

Java过滤特殊字符的正则表达式_java正则表达式过滤特殊字符-程序员宅基地

文章浏览阅读2.1k次。【代码】Java过滤特殊字符的正则表达式。_java正则表达式过滤特殊字符

CSS中设置背景的7个属性及简写background注意点_background设置背景图片-程序员宅基地

文章浏览阅读5.7k次,点赞4次,收藏17次。css中背景的设置至关重要,也是一个难点,因为属性众多,对应的属性值也比较多,这里详细的列举了背景相关的7个属性及对应的属性值,并附上演示代码,后期要用的话,可以随时查看,那我们坐稳开车了······1: background-color 设置背景颜色2:background-image来设置背景图片- 语法:background-image:url(相对路径);-可以同时为一个元素指定背景颜色和背景图片,这样背景颜色将会作为背景图片的底色,一般情况下设置背景..._background设置背景图片

Win10 安装系统跳过创建用户,直接启用 Administrator_windows10msoobe进程-程序员宅基地

文章浏览阅读2.6k次,点赞2次,收藏8次。Win10 安装系统跳过创建用户,直接启用 Administrator_windows10msoobe进程

PyCharm2021安装教程-程序员宅基地

文章浏览阅读10w+次,点赞653次,收藏3k次。Windows安装pycharm教程新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注脚注释也是必不可少的KaTeX数学公式新的甘特图功能,丰富你的文章UML 图表FLowchart流程图导出与导入导出导入下载安装PyCharm1、进入官网PyCharm的下载地址:http://www.jetbrains.com/pycharm/downl_pycharm2021

《跨境电商——速卖通搜索排名规则解析与SEO技术》一一1.1 初识速卖通的搜索引擎...-程序员宅基地

文章浏览阅读835次。本节书摘来自异步社区出版社《跨境电商——速卖通搜索排名规则解析与SEO技术》一书中的第1章,第1.1节,作者: 冯晓宁,更多章节内容可以访问云栖社区“异步社区”公众号查看。1.1 初识速卖通的搜索引擎1.1.1 初识速卖通搜索作为速卖通卖家都应该知道,速卖通经常被视为“国际版的淘宝”。那么请想一下,普通消费者在淘宝网上购买商品的时候,他的行为应该..._跨境电商 速卖通搜索排名规则解析与seo技术 pdf

推荐文章

热门文章

相关标签