Dubbo RPC-Redis协议

Redis协议

特性说明

Redis 是一个高效的 KV 存储服务器。基于 Redis 实现的 RPC 协议。

2.3.0 以上版本支持。

使用场景

缓存,限流,分布式锁等

使用方式

引入依赖

从 Dubbo 3 开始,Redis 协议已经不再内嵌在 Dubbo 中,需要单独引入独立的模块

<dependency>
    <groupId>org.apache.dubbo.extensions</groupId>
    <artifactId>dubbo-rpc-redis</artifactId>
    <version>1.0.0</version>
</dependency>

注册 redis 服务的地址

RegistryFactory registryFactory = ExtensionLoader.getExtensionLoader(RegistryFactory.class).getAdaptiveExtension();
Registry registry = registryFactory.getRegistry(URL.valueOf("zookeeper://10.20.153.10:2181"));
registry.register(URL.valueOf("redis://10.20.153.11/com.foo.BarService?category=providers&dynamic=false&application=foo&group=member&loadbalance=consistenthash"));

在客户端引用

不需要感知 Redis 的地址

在客户端使用:

<dubbo:reference id="store" interface="java.util.Map" group="member" />

或者点对点直连:

<dubbo:reference id="store" interface="java.util.Map" url="redis://10.20.153.10:6379" />

也可以使用自定义接口:

<dubbo:reference id="store" interface="com.foo.StoreService" url="redis://10.20.153.10:6379" />

其中 "p:xxx" 为 spring 的标准 p 标签

<dubbo:reference id="cache" interface="com.foo.CacheService" url="redis://10.20.153.10:6379" p:set="putFoo" p:get="getFoo" p:delete="removeFoo" /

spring boot + Dubbo + Redis注册中心 实现RPC调用

众所周知 dubbo推荐使用zookeeper做服务发现,但今天我们来使用另一种Redis做服务发现 这样省去了维护两种服务的经历 并且可以用作生产

POM

XML 复制代码
  <dependency>
       <groupId>com.alibaba.spring.boot</groupId>
       <artifactId>dubbo-spring-boot-starter</artifactId>
       <version>2.0.0</version>
   </dependency>
   <!--redis 依赖-->
   <dependency>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-data-redis</artifactId>
   </dependency>
   
   <dependency>
       <groupId>org.apache.commons</groupId>
       <artifactId>commons-lang3</artifactId>
       <version>3.7</version>
   </dependency>

dubbo server

dubbo server 服务提供者 application.yml

XML 复制代码
spring:
  application:
    name: dubbo-producer
  dubbo:
    provider:
      threadpool: fixed
      threads: 2000
    application:
      id: server-producer
      name: server-producer
      qos-enable: true
      qos-port: 22222
      qos-accept-foreign-ip: false
    registry:
      # 使用redis 注册中心暴露服务地址
      address: redis://127.0.0.1:6379
    protocol:
      name: dubbo
      # 高效序列化 kryo, fst
      #用dubbo协议在20880端口暴露服务
      port: 20884
    #性能监控中心地址
    monitor:
      protocol: dubbo
      address: 127.0.0.1:7070
    scan: cn.itcast.service
server:
  port: 8888

dubbo服务提供者中创建service接口

java 复制代码
public interface IDubboDemoService {
      String helloDubbo();
  }

service接口实现

java 复制代码
import com.alibaba.dubbo.config.annotation.Service;

//@Service(version = "2.0.0")
@DubboService(version = "3.0.0", group = "dev", timeout = 5000)
public class IDubboDemoServiceImpl implements IDubboDemoService {
@Override
  public String helloDubbo() {
      return "hello dubbo, 我是提供者";
  }

}

dubbo client

dubbo client服务消费者 application.yml

XML 复制代码
spring:
application:
  name: dubbo-consumer
dubbo:
  provider:
    threadpool: fixed
    threads: 2000
  application:
    #      id: database-consumer
    name: database-consumer
  #      qos-enable: true
  #      qos-port: 33333
  #      qos-acceptforeign-ip: false
  registry:
    #使用redis注册中心暴露服务地址
    address: redis://127.0.0.1:6379
  monitor:
    #      protocol: dubbo
    address: 127.0.0.1:7070
server:
port: 9988

dubbo client 服务消费者service接口要与提供者接口名称相同

java 复制代码
public interface IDubboDemoService {
  String helloDubbo();
}    
java 复制代码
@Service
public class IDubboDemoServiceImpl implements IDubboDemoService {
  
  @Override
  //该内容随便写
  public String helloDubbo() {
      return "hello dubbo, I'm server!";
  }
  }

@Service 来自spring依赖

创建自己的接口

java 复制代码
public interface IDemoService {
  String test();
}
java 复制代码
@Service
public class DemoServiceImpl implements IDemoService {
  //调用dubbo服务
 // @Reference(version = "2.0.0")
 @DubboReference(version = "3.0.0")
  public IDubboDemoService dubboDemoService;
  @Override
  public String test() {
      return    dubboDemoService.helloDubbo();
  }
}

启动类

java 复制代码
@SpringBootApplication
@EnableDubbo
@DubboComponentScan(basePackages = "cn.itcast.service")
public class DubboServiceApplication {

    public static void main(String[] args) {
        SpringApplication.run(DubboServiceApplication.class,args);
    }
}

Spring Boot 注解默认只会扫描 main 类所在的 package,如果服务定义在其它 package 中,需要增加配置 EnableDubbo(scanBasePackages = {"org.apache.dubbo.springboot.demo.provider"})

伪代码

@Autowired(required = false)

private IDemoService demoService;

@GetMapper("/get")

demoService.test

即可返回"hello dubbo, 我是提供者"

相关推荐
IT闫2 天前
【Dubbo+Zookeeper】——SpringBoot+Dubbo+Zookeeper知识整合
分布式·zookeeper·云原生·dubbo
T0uken2 天前
【Docker】百度网盘:基于VNC的Web访问及后台下载
前端·docker·dubbo
阿猿收手吧!8 天前
【Docker】容器被停止/删除的方式及命令:全面解析与实践指南
运维·docker·容器·面试·eureka·dubbo
三天不学习8 天前
Uniapp 获取定位详解:从申请Key到实现定位功能
uni-app·dubbo
m0_748246619 天前
Java进阶:Dubbo
java·开发语言·dubbo
阿里云云原生10 天前
使用 Apifox、Postman 测试 Dubbo 服务,Apache Dubbo OpenAPI 即将发布
apache·dubbo·postman
俏布斯12 天前
服务发现(Dubbo-zookeeper)
zookeeper·服务发现·dubbo
CopyLower12 天前
ZooKeeper 和 Dubbo 的关系:技术体系与实际应用
分布式·zookeeper·dubbo
m0_7482409114 天前
Spring Boot项目中解决跨域问题(四种方式)
spring boot·后端·dubbo
AI大模型训练家16 天前
SpringBoot+Dubbo+zookeeper 急速入门案例
java·开发语言·spring boot·学习·dubbo·java-zookeeper