使用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;
    // 方法
}
相关推荐
刘一说7 小时前
Nacos 与 Spring Cloud Alibaba 集成详解:依赖、配置、实战与避坑指南
spring boot·spring cloud·微服务·架构
i***48617 小时前
微服务生态组件之Spring Cloud LoadBalancer详解和源码分析
java·spring cloud·微服务
周杰伦_Jay9 小时前
【Go 语言主流 Web】 框架详细解析
开发语言·后端·微服务·架构·golang
闲人编程9 小时前
Django微服务架构:单体应用拆分解耦实践
微服务·架构·消息队列·django·api·通信·codecapsule
豆浆Whisky9 小时前
Go微服务通信优化:从协议选择到性能调优全攻略|Go语言进阶(20)
后端·微服务·go
拾忆,想起10 小时前
Dubbo服务超时与重试策略配置指南:构建 resilient 微服务架构
服务器·网络·微服务·云原生·架构·dubbo
杭州杭州杭州11 小时前
实验3 微服务介绍以及开发环境搭建
微服务·云原生·架构
p***c94916 小时前
后端在微服务中的服务网关
微服务·云原生·架构
summer_west_fish1 天前
单体VS微服务:架构选择实战指南
java·微服务·架构
q***16081 天前
SpringCloud 系列教程:微服务的未来(二)Mybatis-Plus的条件构造器、自定义SQL、Service接口基本用法
spring cloud·微服务·mybatis