Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Apache Dubbo实际应用总结

Apache Dubbo实际应用总结

作者头像
MavenTalker
发布于 2019-07-19 02:55:42
发布于 2019-07-19 02:55:42
5890
举报
文章被收录于专栏:歪脖贰点零歪脖贰点零
Dubbo实际应用总结

一方面是SpringCoud微服务框架如火如荼的发展,另一方面随着Dubbo的重启,接着又捐献给Apache社区,Dubbo在国内技术市场上又重新攻城略地,随着孵化即将毕业,以后正式称为Apache Dubbo,相应会应用的更加广泛。

下面罗列几点Dubbo在项目的应用,没有特别复杂的场景,简单做个总结,Dubbo上手容易,但用的好还是有难度的。

1.超时

Timeout设置依据就近原则,服务提供者的优先级低于调用者,类级别的优先级低于方法级别的

2.异步调用

使用async='true',即可完成异步调用。初级应用时未能仔细查看API,异步实现时,自己实现多线程来进行,这完全是忽略了dubbo本来的特性。

3.spring-boot-starter

随着SpringBoot的普及,Dubbo 的starter一键引入版也是呼欲出。一个是alibaba/dubbo-spring-boot-starter,1.4k+Star,Dubbo在移交后Apache孵化期间,该项目已经停止维护,进行封存阶段。另一个是apache/incubator-dubbo-spring-boot-project,目前2.6k+Star,应该说未来的官方版,活跃度很高。

4.缓存目录

dubbo应用期间,默认存储在/root/.dubbo目录,会发现有两类文件,一个application_name-ip-port.cacahe和lock文件,cache文件中保存着该应用所有注册的服务。当有些时候发布的时候无法调用到时,可以清理此文件,重新注册服务。

5.同接口不同实现,分组

经常会遇到相同接口不同实现的情况,可结合Spring配置@Qualifier注解,再给接口定义时增加group参数即可。

6.非幂等接口设置不重试

请求超时时,默认值是2。如果是非幂等性接口,一定要此参数设置为0。dubbo-spring-boot-starter的0.2.0版本中必须设置为-1才能不重试。

7.独立开发不走dubbo

新产品独立开发时(如果有外部依赖可采用mock方式),可完全采用jar内部依赖的方式进行,到正式测试时,再分解后不同的服务启动,可以提高开发阶段的效率。

8.增加版本

尽量给每个接口加个版本号,便于后期接口变更时进行兼容性升级。

9.Mock处理

在接口不完善的情况下,可直接通过Mock形式为接口调用方返回结果,保证接口可用,不影响调用测试。采用mock配置即可。

10.HTTP支持。

Dubbo在大家的印象中,只做内部服务调用,在Dubbo重启维护后的2.6.0版本中,将Dubbox的分支合并到主干,以此可以对外提供语言无关的HTTP接口服务。Apache Dubbo已不再局限于Java语言

11.异常自定义处理

使用Dubbo后,发现抛出来的异常都是RuntimeException,不能很友好提示给用户,这时需要自定义异常。扩展Dubbo的一个Filter,将自定义的异常写进去。同时定义好com.alibaba.dubbo.rpc.Filter文件,以便能正确寻址到自定义的异常类。

12.链路追踪

虽然Dubbo内置了brave实现,但使用起来不是很方便,可以采用官方推荐的两种方式:Pinpoint和Skywalking,有更好的UI界面方便跟踪查询,再结合日志查询系统,如ELK Stack进行异常定位。

13.监控平台

原来的dubbo-admin子项目,迁移到dubbo-ops项目中来独立发展。在dubbo-admin中可进行接口的负载、容错、权重的配置等等。

14.分布式事务

近基于开源的FESCAR,对Dubbo进行了完美的支持,分布式事务开源解决方案——FESCAR

往期推荐:

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-01-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 MavenTalk 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
sofa-rpc和dubbo2.x对比
去年得知蚂蚁金服放出SOFA的部分开源项目, RPC部分号称源于阿里内部的HSF, HSF当年可是把dubbo 1.x踢出局的, 只是没想到京东改造dubbo为JSF, 当当改为dubbox。国内蛮多电商公司实施服务化就直接上dubbo 1.x或dubbox。这应该是阿里没想到的, 所以现在dubbo 2.x又回笼为apache的顶级项目, 把dubbox合并还继续完善。
Zeal
2020/11/10
4.8K0
Dubbo介绍、原理
Dubbo是一个分布式服务框架,以及SOA治理方案。其功能主要包括:高性能NIO通讯及多协议集成,服务动态寻址与路由,软负载均衡与容错,依赖分析与降级等。
DannyHoo
2022/04/02
2.3K0
Dubbo介绍、原理
Spring Boot + Dubbo + Zookpeer分布式案例
Zookeeper:https://downloads.apache.org/zookeeper/
闫同学
2023/11/05
2330
Apace dubbo学习笔记(一)
Dubbo是阿里巴巴开发的一个开源的高性能、高可用、可扩展的分布式RPC调用框架,致力于提供高性能和透明化的 RPC 远程调用服务解决方案。作为阿里巴巴 SOA 服务化治理方案的核心框架,目前已进入 Apache 孵化器项目。在单体应用时,不同业务模块部署在同一个JVM 进程内,这时通过本地调用就可以解决不同业务模块之间的相互引用;但在多体应用时,不同业务模块大多部署到不同的机器上,这时一个高效、稳定的RPC框架就显得特别重要了。Apache Dubbo 作为阿里巴巴开源的分布式RPC 框架,在进入Apache 孵化器项目后现已毕业。就目前来说Dubbo是java这块做分布式服务的流行方式。加之dubbo在云原生方面的探索都是我们作为java开发者应该且必须掌握的一门编程技术。就目前来说java的rpc框架包括hession都没有像dubbo这样支持负载均衡的功能。我们知道rpc调用其实相比http这种的各种json转化方便很多,而且不用关注类似鉴权等一些操作,个人觉得或许不是最好的解决方案。诸如此,作者计划学习一下dubbo,而本次学习本着深入了解的思路,尽量发掘dubbo的的设计方式,作为学习的开始,我们还是从demo开始吧。
写一点笔记
2022/08/11
2030
Apace dubbo学习笔记(一)
Dubbo: 基于SpringBoot+Dubbo的Provider/Consumer的实践
1.首先我们需要提供一个Dubbo RPC API 接口,Provider服务需要实现该接口并且导出,Consumer客户端需要调用该接口。
Freedom123
2024/03/29
4600
SpringBoot 2.0 + Apache Dubbo 2.7.3 最新版整合方案
2018年2月16日,Apache Dubbo 加入 Apache 基金会孵化器。2019年5月16日,Apache 软件基金会董事会决议通过了 Apache Dubbo 的毕业申请,这意味着 Apache Dubbo 正式成为 Apache 的顶级项目。
小柒2012
2019/12/05
2K0
spring|springboot集成dubbo
现在国内中小公司,远程调用基本上用的都是dubbo ,当然小刀的公司也不例外,我们以前用的是dubbo 2.4.x的版本,虽然也能使用,但是本着新项目新技术的追求,我们更新成了dubbo 2.7.x 的版本
微笑的小小刀
2019/08/06
1.4K0
spring|springboot集成dubbo
SpringBoot2.0 整合 Dubbo框架 ,实现RPC服务远程调用
图例说明: 1)图中小方块 Protocol, Cluster, Proxy, Service, Container, Registry, Monitor 代表层或模块,蓝色的表示与业务有交互,绿色的表示只对 Dubbo 内部交互。 2)图中背景方块 Consumer, Provider, Registry, Monitor 代表部署逻辑拓扑节点。 3)图中蓝色虚线为初始化时调用,红色虚线为运行时异步调用,红色实线为运行时同步调用。 4)图中只包含 RPC 的层,不包含 Remoting 的层,Remoting 整体都隐含在 Protocol 中。
知了一笑
2019/07/19
2.1K0
SpringBoot2.0 整合 Dubbo框架 ,实现RPC服务远程调用
dubbo入门详解[通俗易懂]
随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进。
全栈程序员站长
2022/09/22
7270
Spring Cloud Alibaba + Dubbo 搭建一个微服务架构
在阅读这篇文章前,推荐一篇“好”文章:MediaCrawler 提取评论生词云:小红书实例-麦琳评论区
王二蛋
2024/11/27
2490
Spring Boot 整合 Dubbo,Zookeper,Dubbo-Admin 教程 不涉及原理
说明,上面排除了 slf4j-log4j12 依赖,不排除会报错,这里我忘记了爆的是包重复依赖还是其他问题
收心
2022/01/14
3800
Spring Boot 整合 Dubbo,Zookeper,Dubbo-Admin 教程 不涉及原理
Dubbo 2.7新特性之异步化改造
我是2016年毕业的,在我毕业之前,我在学校里面学到的框架都是SSH,即struts+spring+hibernate,是的你没有看错,在大学里面的课本里面学的是strusts,这个还没毕业就被基本抛弃的框架。然而我大四出去实习,用的技术是SSM,即Spring,SpringMVC,Mybatis。实习的时候做的项目都是外包项目,非常传统的单体大项目,和学校里面做课程设计一样,所有的功能包括前后端都糅合在一个项目里面,根本不知道什么是分布式架构,不夸张的说,那个时候我对分布式这一块的知识无限趋近于零。
why技术
2019/09/18
1.2K0
Dubbo 2.7新特性之异步化改造
Dubbo2.7 三大新特性详解
自 2017 年 7 月阿里重启 Dubbo 开源,到目前为止 github star 数,contributor 数都有了非常大的提升。2018 年 2 月 9 日阿里决定将 Dubbo 项目贡献给 Apache,经过一周的投票,顺利成为了 Apache 的孵化项目,也就是大家现在看到的 Incubator Dubbo。预计在 2019 年 4 月,Dubbo 可以达成毕业,成为 Apache 的顶级项目。
kirito-moe
2019/04/30
1.2K0
Dubbo2.7 三大新特性详解
精选Dubbo面试题(43题)
简单的说,RPC就是从一台机器(客户端)上通过参数传递的方式调用另一台机器(服务器)上的一个函数或方法(可以统称为服务)并得到返回的结果
一行Java
2022/04/07
5960
精选Dubbo面试题(43题)
Doubbox 入门学习
Dubbo提供启动时配置、XML配置、properties以及yml配置 优先级
Java_慈祥
2024/08/06
1060
Doubbox 入门学习
Dubbo基本使用与原理详解
当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。此时,用于简化增删改查工作量的数据访问框架(ORM)是关键。
麋鹿大哥
2020/12/31
12K0
Dubbo基本使用与原理详解
【万字长文】Dubbo 入门总结 ,一款高性能的 Java RPC 框架
这篇文章是我学习整理 Dubbo 的一篇文章,首先大部分内容参考了官网 + 某硅谷的视频,内容讲解进行了重新编排,40多张图片,也都是我修改重制的,虽然一万多字,但是其实也可以看出来,更多的内容集中在了概念或功能的介绍,具体环境的搭建,以及如何配置,快速上手上面,但是对于这样一款优秀的框架,文章中提到的每一个点其实展开来讲都能写这样篇幅的一篇文章,仅仅入门来看也没必要,总得学会走,才可以去试着跑
BWH_Steven
2020/12/14
6700
【万字长文】Dubbo 入门总结 ,一款高性能的 Java RPC 框架
Spring Boot Dubbo 构建分布式服务
具体代码可以查看 github 的 dubbo 模块:https://github.com/UniqueDong/springboot-study
码哥字节
2021/07/27
3730
企业级SpringBoot与Dubbo的并用
SpringBoot越来越热门以至于达到烂大街可见的程度,而Dubbo这个基于二进制的微服务框架又捐献给Apache孵化,如果不会如何使用那么是不是很不好意思呢?
lyb-geek
2019/05/29
1.2K0
快速学习-Skywalking的RPC调用-Dubbo的最佳实践
接下来为大家提供一些简单使用Dubbo服务调用的项目代码演示, 大家可以参考下面简单版 或者详细请参照Demo中的脚手架示例scaffold-dubbo-demo
cwl_java
2020/08/10
1.9K0
快速学习-Skywalking的RPC调用-Dubbo的最佳实践
相关推荐
sofa-rpc和dubbo2.x对比
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档