使用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;
    // 方法
}
相关推荐
xiaoshuaishuai811 小时前
C# 实现百度搜索算法逆向
开发语言·windows·c#·dubbo
尽兴-13 小时前
Dubbo3.0新特性介绍与使用
dubbo·dubbo3.0
数字化顾问15 小时前
(88页PPT)DG1092D1S4培训课件EASGERP总体架构基础(附下载方式)
微服务·云原生·架构
codeejun16 小时前
每日一Go-51、Go微服务--API网关-Kong
微服务·golang·kong
波波00716 小时前
每日一题:什么是CQRS,在微服务中如何应用
微服务·架构
大罗LuoSir17 小时前
分布式微服务全貌了解-整体架构、特征和需关注解决的问题
java·缓存·微服务·zookeeper·容器·服务发现·负载均衡
aXin_ya17 小时前
微服务 第一天
java·运维·微服务
aXin_ya18 小时前
微服务 第二天
java·数据库·微服务
码界奇点18 小时前
基于Spring Boot的插件化微服务热更新系统设计与实现
spring boot·后端·微服务·架构·毕业设计·源代码管理
尽兴-19 小时前
Dubbo 负载均衡原理与服务调用全解析
运维·负载均衡·dubbo·轮询算法·一致性哈希·平滑加权轮询·随机算法