使用Dubbo实现微服务之间的高效通信

目录

一、RPC与Dubbo

二、Springboot整合Dubbo

服务端实现

消费端实现


一、RPC与Dubbo

RPC(Remote Procedure Call)是指远程过程调用。

常见的RPC框架有Dubbo (Alibaba )、gRPC (Google)、Thrift(Facebook)。

其中

Dubbo是一款Java RPC框架,致力于提供高性能的RPC远程服务调用方案。以帮助开发人员快速构建高效的分布式系统。Alibaba 是其主要贡献者。

二、Springboot整合Dubbo

确保项目中已经存在dubbo依赖,可以直接添加spring-cloud-alibaba-dependencies依赖到项目中,spring-cloud-alibaba-dependencies依赖于spring-cloud-starter-dubbo,spring-cloud-starter-dubbo依赖于dubbo。

XML 复制代码
<!-- SpringCloud Alibaba 微服务 -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-alibaba-dependencies</artifactId>
    <version>${spring-cloud-alibaba.version}</version>
    <type>pom</type>
    <scope>import</scope>
</dependency>

服务端实现

在服务端bootstrap.yml中添加配置以下配置

XML 复制代码
# Dubbo        
dubbo:
   application:
      name: diggl-base-system
      qos-enable: false #不启用qos,启用的话会报端口被占用
   scan: # 指定 Dubbo 服务实现类的扫描基准包
      base-packages: com.diggl.base.system.service
   protocol: # 协议
      name: dubbo
      port: -1 # rpc需要一个额外的端口,-1 表示端口随机
   registry: # 注册中心
      address: nacos://localhost:8848?username=diggl&password=diggl
   consumer:
     check: false   # 引用服务没有注册时,不报错
     timeout: 6000

@DubboService注解用在类上,告诉Dubbo这个类是一个服务提供者,Dubbo会自动检测这个类并注册到注册中心。

java 复制代码
/**
 * @description 远程用户Service实现类
 */
@DubboService
public class RemoteUserServiceImpl implements RemoteUserService {
    // 方法
}

消费端实现

在消费端bootstrap.yml中添加配置以下配置

XML 复制代码
# Dubbo        
dubbo:
   application:
      name: diggl-auth
      qos-enable: false #不启用qos,启用的话会报端口被占用
   protocol:
      name: dubbo    
      port: -1 # rpc需要一个额外的端口,-1 表示端口随机
   registry:
      address: nacos://localhost:8848?username=diggl&password=diggl
   cloud:
      subscribed-services: diggl-base-system,diggl-apigateway-service
   consumer:
      check: false
      timeout: 60000

@DubboReference注解告诉Dubbo当前类是一个服务消费者,Dubbo会自动检测这个类并从注册中心获取被注解的服务提供者对象的信息,并建立与服务提供者的通信。(@Reference注解是Dubbo早期的版本中使用的)

java 复制代码
/**
 * 登录校验
 */
@Component
public class SysLoginService {
    @DubboReference
    private RemoteUserService remoteUserService;
    // 方法
}
相关推荐
hzzzzzo04 小时前
微服务核心组件实战:Nacos 与 Ribbon 的应用
spring cloud·微服务·ribbon·nacos·架构
gengsa10 小时前
使用 Telepresence 做本地微服务项目开发
后端·微服务
u01040583610 小时前
基于微服务架构的电商返利APP技术架构设计与性能优化策略
微服务·性能优化·架构
阿里云云原生15 小时前
阿里云微服务引擎 MSE 及 API 网关 2025 年 8 月产品动态
微服务
AppleWebCoder16 小时前
Java大厂面试实录:AIGC与虚拟互动场景下的微服务与AI落地(附知识详解)
java·spring boot·微服务·ai·消息队列·aigc·虚拟互动
hzzzzzo019 小时前
微服务通信实战篇:基于 Feign 的远程调用与性能优化
微服务·性能优化·架构
阿里云云原生1 天前
稳定支撑大规模模型调用,携程旅游的 AI 网关实践
微服务
妄小闲1 天前
百度竞价推广:搜索竞价信息流推广代运营
dubbo
叫我阿柒啊1 天前
从Java全栈到前端框架的实战之路
java·数据库·微服务·typescript·前端框架·vue3·springboot
蒋星熠1 天前
WebSocket网络编程深度实践:从协议原理到生产级应用
网络·数据库·redis·python·websocket·网络协议·微服务