Dubbo技术问答系列-NO5

119 篇文章 0 订阅
42 篇文章 0 订阅

一.Dubbo SPI 和 Java SPI区别?

Dubbo SPI和Java SPI在设计和功能上存在一些显著的区别,具体如下:

  1. 设计初衷与定位:
    • Java SPI(Service Provider Interface)是Java标准版中提供的一种服务发现机制。它的主要目标是允许应用程序动态地加载和使用第三方提供的服务实现,而无需在代码中显式引用这些实现类。SPI体现了基于接口编程的思想,通过将服务接口和其实现解耦,使得应用程序的核心逻辑与具体的服务提供者分离,从而实现更好的可扩展性和可维护性。
    • Dubbo SPI则是基于Java SPI的一种增强机制。它的主要目标是提供更为灵活和强大的扩展能力,以满足Dubbo这类分布式服务框架的复杂需求。Dubbo SPI不仅继承了Java SPI的基本功能,还在此基础上进行了扩展和优化。
  1. 配置文件与内容:
    • Java SPI的配置文件内容通常是单一的实现类的全限定类名,这些文件通常存储在META-INF/services目录下。
    • Dubbo SPI的配置文件内容则更为丰富,可以包含多个扩展实现。每个扩展实现对应一个键值对,键是扩展实现的名字,值是扩展实现的全限定类名。这种设计使得Dubbo SPI能够支持更为复杂的扩展场景,如动态替换和自适应扩展。
  1. 扩展性与灵活性:
    • Dubbo SPI相对于Java SPI提供了更高级别的扩展性。它支持在配置文件中配置多个扩展实现,并且可以在运行时动态地修改和替换这些实现。这使得Dubbo SPI能够更好地适应不断变化的服务需求,提高了系统的灵活性和可维护性。
    • Java SPI虽然也提供了服务发现的能力,但一旦加载,就固定使用配置文件中的实现,不支持动态替换和自适应扩展。
  1. 使用场景:
    • Java SPI通常用于一些需要动态加载第三方服务实现的场景,例如JDBC驱动加载等。
    • Dubbo SPI则更适用于分布式服务框架等复杂场景,它可以帮助开发者更加灵活地管理和扩展服务实现,提高系统的可扩展性和可维护性。

二.Dubbo支持分布式事务吗?

是的,Dubbo支持分布式事务。

Dubbo支持多种分布式事务模式,包括XA、TCC和SAGA等。其中,TCC模式是通过补偿机制实现分布式事务的,即每个业务操作都需要定义一个与之对应的补偿操作,当业务操作失败时,通过执行补偿操作来回滚之前的业务操作,以此保证数据的一致性。

三.Dubbo可以对结果进行缓存吗?

是的,Dubbo可以对结果进行缓存。Dubbo提供了结果缓存机制,用于加速热门数据的访问速度,并减少用户加缓存的工作量。这种缓存机制的目标是将服务请求的响应结果缓存起来,以减轻后续相同请求的服务调用压力。

Dubbo支持三种结果缓存机制:

  1. LRU:基于最近最少使用原则删除多余缓存,保持最热的数据被缓存。
  2. ThreadLocal:当前线程缓存,比如一个页面渲染,用到很多portal,每个portal都要去查用户信息,通过线程缓存,可以减少这种多余访问。
  3. JCache:与JSR107集成,可以桥接各种缓存实现。

四.Dubbo必须依赖的包有哪些?

  1. Dubbo核心包:这是Dubbo框架的核心组成部分,包含了Dubbo实现远程过程调用、容器管理等功能的必需类库。这些包通常包括dubbo-common、dubbo-remoting、dubbo-rpc和dubbo-container等,具体的版本可能会有所不同,例如dubbo-common-2.7.8.jar、dubbo-remoting-2.7.8.jar、dubbo-rpc-2.7.8.jar和dubbo-container-2.7.8.jar等。
  2. JDK:Dubbo的运行需要依赖JDK,推荐使用JDK 8或以上版本。
  3. Dubbo用户手册:虽然这不是一个必需的依赖包,但dubbo-user-book.pdf等文档对于理解和使用Dubbo框架来说是非常重要的,它们提供了Dubbo的使用指南和相关说明。
  • 28
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

纵然间

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值