Service mesh时代,Dubbo架构该怎么跟进?

2024-01-05 16:10

本文主要是介绍Service mesh时代,Dubbo架构该怎么跟进?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

导读:6月21-23日,2019 GIAC全球互联网架构大会将于深圳举行。GIAC是面向架构师、技术负责人及高端技术从业人员的年度技术架构大会,是中国地区规模最大的技术会议之一。今年GIAC邀请到了众多布道师、明星讲师以及105位来自Google、微软、Oracle、eBay、百度、阿里、腾讯、商汤、图森、字节跳动、新浪、美团点评等公司专家出席。


在大会前夕,高可用架构采访了本届 GIAC Java分论坛讲师小马哥,就目前大家广泛关注的Dubbo/微服务相关的问题进行了访谈。


640?wx_fmt=pngJava 劝退师,Apache Dubbo PMC、Spring Cloud Alibaba 项目架构师,《Spring Boot 编程思想》的作者。目前主要负责集团中间件开源项目、微服务技术实施、架构衍进、基础设施构建等。通过 SUN Java(SCJP、SCWCD、SCBCD)以及 Oracle OCA 等的认证。


邓启明:小马哥您好,我是高可用架构的编辑邓启明,很高兴采访到您。请先简单介绍下自己。


小马哥:大家好,我是小马哥(mercyblitz),一名学习当爸爸的父亲,Java 劝退师 (https://www.douyu.com/mercyblitz),Apache Dubbo (https://dubbo.apache.org/) PMC、Spring Cloud Alibaba (https://github.com/spring-cloud-incubator/spring-cloud-alibaba)项目架构师,《Spring Boot 编程思想》的作者。目前主要负责集团中间件开源项目、微服务技术实施、架构衍进、基础设施构建等。


邓启明简单介绍下你自己的从业经历?


小马哥:今年是我从业的第十二个年头,这些年一直在从事 Java 研发。首个雇主是一家外企公司,为其服务了三年。外企的工作相对轻松,拥有充分的自主时间提升技能,同时也有机会提升英语水平。期间通过了 SUN Java(SCJP、SCWCD、SCBCD)以及 Oracle OCA 等的认证,尽管这些证书并没有受到国内雇主的重视,不过对我后续的职业产生了深远的影响。当然,事情并不是总是积极正面,东西方文化差异,以及部分外籍同事的傲慢与偏见着实让本人对西方的技术和文化重新开始审视。既然无法改变,那么离开并继续深造或许是必然的选择,希望有一天能够通过共同的努力,让世界看到中华的进步。于是,我的第一份工作就在 2010 年 10 月 1 号画上了句点。迎接我的是第二份工作,至今也快九个年头。这几年,我经历了很多、学到了很多,也成长了很多,岂能尽如人意,但求无愧我心。不可否认的是,儒家思想对我的影响最为深刻,它让我学会独立、理性以及辩证的思考,培养我处变不惊的人生态度,直接或间接地提升了专业素质。经过数年的沉寂,我也明确了自己的方向,辗转投入开源社区的建设。不过,纵使浑身是铁能打几根钉,开源社区的发展需要更多的能人参与,知之者不如好之者,好之者不如乐之者。然而现实的情况又有些残酷,不少的年轻人在经济的压力下,逐渐失去对技术的追求。于是从 2016 年开始,我便尝试做一些技术分享,希望能够帮助到部分年轻从业人员,使他们对技术产生兴趣。随后,我又着手编写《Spring Boot 编程思想》,希望读者能够理解规范和基础的重要性,如果读者从中能够培养自己系统化的知识体系或者思维方式,那就善莫大焉了。我也时常鼓励更多的小伙伴多多分享,无论是免费,还是收费。同时,注重知识产权的保护,树立良好的生态环境。当然,我的第二份职业尚未告一段落,或许等它结束之际,方可“盖棺定论“。总之,但行好事,莫问前程。


邓启明请介绍下 Dubbo 的现状?

小马哥:2019年5月16日,Apache 软件基金会董事会决议通过了 Apache Dubbo 的毕业申请,这意味着 Apache Dubbo 正式成为 Apache 的顶级项目。Apache Dubbo 项目在 Github 上的 star 数已超过 2.7 万,contributors 人数达到 202,Commiters 人数也升至 32 人,借此机会感谢所有关系和参与 Apache Dubbo 建设的小伙伴。目前,项目主要包含三大核心的分支,均在并行开发。其中,2.6.x 处于维护状态;2.7.x 聚焦云原生微服务方向,3.0.x 则指定未来标准和技术走向。简言之,Dubbo 不再是纯粹的 Java 服务治理 PRC 框架,已经逐渐成为多语种 Cloud Native 基础设施的中坚力量。


邓启明Dubbo 开源以来,代码贡献者中阿里本身的开发者占绝大多数,这是否意味着来自阿里的需求会起主导作用?在后续的发展过程中,计划如何引入阿里之外的开发者?


小马哥:尽管目前 Apache Dubbo 代码贡献者主要来自于阿里的开发人员,不过这个比重正在迅速地变小,一方面说明 Dubbo 用户人数在逐渐变大,专业程度在不断地变深,同时,也说明有意主导并且贡献的小伙伴越来越活跃。这无论对社区的发展,还是从业人员的职业技能均有裨益。因此,需求的来源不再已阿里为绝对主导,社区共建和共制的发展模式已成事实。


邓启明在未来一年,Dubbo的新特性路线图可以简单介绍下吗?

小马哥:由于 Dubbo 2.6.x 处于维护状态,不会新增明显的功能特性。


本年度主要的发力点在 Dubbo 2.7 这个版本上,该版本致力于 Cloud Native 以及微服务领域,大致的路线计划为:

* 2.7.2 - Metrics、etcd 元数据、nacos 配置与元数据以及 2.6 兼容

* 2.7.3 - Cloud Native 注册机制、服务自省以及 Dubbo Proxy

* 2.7.4 - K8s 原生支持(服务发现、元数据存储和配置推送)、Dubbo GO 以及 gRPC 集成

* 2.7.5 - 服务治理规则支持 Pilot CRD 

* 2.7.6 - 控制面 xDS API 对接


Dubbo 3.0.0 M1 版本的核心特性围绕在 RSocket、Reactive 以及异步化上的支持。 M2 版本计划将在 8 月发布,主要提供对 HTTP/2 的支持和性能调优。接下来的 M3 版本将通过 HTTP/2 支持 gPRC 以及 Rocket 通讯协议。3.0.0 正式的发布将安排在 2020 年的 2 月。

邓启明Spring Cloud 和 Dubbo 在微服务方面的优劣分别是什么?


小马哥:在 Java 生态中,Spring Cloud 和 Dubbo 都是微服务框架。前者被业界常作为 Java 微服务的首选框架,而后者有时被错误地解读为服务治理的 RPC 框架。实际上,两者在微服务架构中并没有本质的差异,均是分布式应用服务治理的框架。


在开发体验方面,Spring Cloud 开箱即用的组件让人印象深刻。在 API 抽象和设计方面,流淌着 Spring 家族血液的 Spring Cloud 延续了父辈的荣耀。由此观之,Dubbo 与其存在差距。 


然而随着实践的不断深入,Spring Cloud 功能的稳定性以及版本的兼容性等问题较为突出。当应用集群达到一定规模时,其分布式经验上的短板也随之暴露,尤其是 Spring Cloud Netflix 套件,比如 Eureka 与 Ribbon 之间的 90 秒延迟会影响服务调用的成功率,以及负载均衡算法缺少权重无法帮助 JVM 预热。简言之,在服务治理方面,Spring Cloud 相较于 Dubbo 而言,并不算太成熟。如果大家有兴趣了解更多的话,可参考「小马哥技术周报」 (https://github.com/mercyblitz/tech-weekly)。


总之,Spring Cloud 和 Dubbo 各有特色,过度地关注彼此优劣并不可取。为此,Spring Cloud Alibaba 项目综合两家之长,提供了一套名为 Dubbo Spring Cloud 的整容实现,使得 Dubbo 与 Spring Cloud 不再是互斥性选项。


邓启明Dubbo在成为Apache顶级项目的过程中,背后有哪些不为人知的故事?

小马哥:Dubbo 在 Apache 从孵化到毕业,期间的确有太多不为人知的故事,这里我简单地介绍一下其中孵化过程:

* 筹备期(2017.12-2018.2):最主要的工作是准备进入孵化器相关的材料,比如寻找合适的导师,编写加入孵化器的提案等。

* 初始期(2018.2-2018.5):主要完成的工作主要是完成知识产权的清理,邮件列表的创建,代码迁移等工作。

* 首次 Release:Apache孵化项目第一个重要的里程碑,第一次Release非常关键,除了确保功能的稳定以外,最重要的就是需要确保引入的代码的许可证符合Apache的政策,Apache对于许可证有着明确的规定。

* 社区发展(Community Building):也是作为一个Apache项目非常看重的一环。最不愿意看到的就是一家公司独大,控制整个项目,对于Dubbo来说,经过这么多年的发展,在国内已经具备了一定的渗透率,有了不少用户,但是他们就像花粉一样散落在各个角落里面,需要做的事情就是把他们都聚集起来。

邓启明Service Mesh 时代,需要什么样的微服务框架?


小马哥:哈哈,需要 Dubbo 这样的框架(玩笑)。首先,个人并不是 Service Mesh 方面的专家,就目前所得到掌握的信息,Service Mesh 并不算成熟的技术,换言之,目前还不是 Service Mesh 的时代,甚至我听到不少的朋友由于性能和稳定性方面的原因,从该架构中退化,这也是 Dubbo 在 Service Mesh 方面的衍进相对缓慢的原因之一。当然,技术的发展总会是在掌声伴随着嘘声中前进,因此,个人对于 Service Mesh 的看法是谨慎乐观的。


邓启明对于公司内部定制Dubbo而言,你有什么建议吗?


小马哥:流水不腐户枢不蠹,我希望这些公司能够积极参与 Dubbo 社区的共建,或许这些定制化的场景也可以服务其他场景。大家互通有无,实现共同进步。


邓启明对于初级开发者而言,学习Dubbo应该如何入手?对于资深开发者而言,怎样研究Dubbo的源代码更加高效?


小马哥:对于初级开发者,我的建议是首先从 Apache Dubbo 官网(https://dubbo.apache.org (http://dubbo.apache.org/))学习《用户文档》,初步了解了 Dubbo 架构和特性后,再结合 Dubbo 官方样例(https://github.com/apache/dubbo-samples)全面掌握 Dubbo 功能和最佳实践。最后,参考官方博客(http://dubbo.apache.org/zh-cn/blog/index.html),深度理解 Dubbo。


对于资深开发者,尤其是那些致力于贡献的小伙伴,我建议参考《开发者文档》,掌握 Dubbo 设计和实现,并且结合 Dubbo 的源码巩固学习,最好直接贡献代码(在 GitHub Pull Request),战胜心中一切的畏惧。如果仍不满足于此,强烈推荐参考 Apache Dubbo PMC 商宗海(花名:诣极)编写书籍 - 《深入理解 Apache Dubbo 与实战》,从中本人也受益匪浅,建议小伙们入手。


邓启明作为Dubbo的开发者,你最喜欢的Java(Java8以后)特性是什么?你最希望加入的Java特性是什么?

小马哥:Java 8 是 Dubbo 2.7 默认的语言级别,其中 Lambda 表达式以及 Stream API 被广泛地使用。除此之外,本人同样偏好使用 CompletableFuture 作为并行编程的 API。我最希望 Java 增加 JVM 级别的协程支持。


邓启明你作为讲师参加GIAC,对本次GIAC大会有何寄语?


小马哥:非常感谢 GIAC 的主办方给本人这次机会分享 Dubbo 相关的的议程,这也是我本人第二次在 GIAC 分享该主题了。我衷心地祝福 GIAC 影响力越做越大,希望能够走出国门,成为具有国际化影响力的技术组织,向世界传播技术和力量。


本届GIAC Java专场/微服务/Service Mesh/Cloud Native的精彩议题如下:

640?wx_fmt=png

640?wx_fmt=png

640?wx_fmt=png

640?wx_fmt=png

这篇关于Service mesh时代,Dubbo架构该怎么跟进?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/573418

相关文章

Ubuntu 怎么启用 Universe 和 Multiverse 软件源?

《Ubuntu怎么启用Universe和Multiverse软件源?》在Ubuntu中,软件源是用于获取和安装软件的服务器,通过设置和管理软件源,您可以确保系统能够从可靠的来源获取最新的软件... Ubuntu 是一款广受认可且声誉良好的开源操作系统,允许用户通过其庞大的软件包来定制和增强计算体验。这些软件

Ubuntu 24.04 LTS怎么关闭 Ubuntu Pro 更新提示弹窗?

《Ubuntu24.04LTS怎么关闭UbuntuPro更新提示弹窗?》Ubuntu每次开机都会弹窗提示安全更新,设置里最多只能取消自动下载,自动更新,但无法做到直接让自动更新的弹窗不出现,... 如果你正在使用 Ubuntu 24.04 LTS,可能会注意到——在使用「软件更新器」或运行 APT 命令时,

TP-LINK/水星和hasivo交换机怎么选? 三款网管交换机系统功能对比

《TP-LINK/水星和hasivo交换机怎么选?三款网管交换机系统功能对比》今天选了三款都是”8+1″的2.5G网管交换机,分别是TP-LINK水星和hasivo交换机,该怎么选呢?这些交换机功... TP-LINK、水星和hasivo这三台交换机都是”8+1″的2.5G网管交换机,我手里的China编程has

mybatis的整体架构

mybatis的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

AI绘图怎么变现?想做点副业的小白必看!

在科技飞速发展的今天,AI绘图作为一种新兴技术,不仅改变了艺术创作的方式,也为创作者提供了多种变现途径。本文将详细探讨几种常见的AI绘图变现方式,帮助创作者更好地利用这一技术实现经济收益。 更多实操教程和AI绘画工具,可以扫描下方,免费获取 定制服务:个性化的创意商机 个性化定制 AI绘图技术能够根据用户需求生成个性化的头像、壁纸、插画等作品。例如,姓氏头像在电商平台上非常受欢迎,

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

W外链微信推广短连接怎么做?

制作微信推广链接的难点分析 一、内容创作难度 制作微信推广链接时,首先需要创作有吸引力的内容。这不仅要求内容本身有趣、有价值,还要能够激起人们的分享欲望。对于许多企业和个人来说,尤其是那些缺乏创意和写作能力的人来说,这是制作微信推广链接的一大难点。 二、精准定位难度 微信用户群体庞大,不同用户的需求和兴趣各异。因此,制作推广链接时需要精准定位目标受众,以便更有效地吸引他们点击并分享链接

电脑桌面文件删除了怎么找回来?别急,快速恢复攻略在此

在日常使用电脑的过程中,我们经常会遇到这样的情况:一不小心,桌面上的某个重要文件被删除了。这时,大多数人可能会感到惊慌失措,不知所措。 其实,不必过于担心,因为有很多方法可以帮助我们找回被删除的桌面文件。下面,就让我们一起来了解一下这些恢复桌面文件的方法吧。 一、使用撤销操作 如果我们刚刚删除了桌面上的文件,并且还没有进行其他操作,那么可以尝试使用撤销操作来恢复文件。在键盘上同时按下“C

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

怎么让1台电脑共享给7人同时流畅设计

在当今的创意设计与数字内容生产领域,图形工作站以其强大的计算能力、专业的图形处理能力和稳定的系统性能,成为了众多设计师、动画师、视频编辑师等创意工作者的必备工具。 设计团队面临资源有限,比如只有一台高性能电脑时,如何高效地让七人同时流畅地进行设计工作,便成为了一个亟待解决的问题。 一、硬件升级与配置 1.高性能处理器(CPU):选择多核、高线程的处理器,例如Intel的至强系列或AMD的Ry