Dubbo3应用开发—XML形式的Dubbo应用开发和SpringBoot整合Dubbo开发

Dubbo3程序的初步开发

Dubbo3升级的核心内容

  • 易⽤性

    开箱即⽤,易⽤性⾼,如 Java 版本的⾯向接⼝代理特性能实现本地透明调⽤功能丰富,基于原⽣库或轻量扩展即可实现绝⼤多数的 微服务治理能⼒。更加完善了多语言支持(GO PYTHON RUST)

  • 超⼤规模微服务实践

    • ⾼性能通信(Triple GRPC)
    • ⾼可扩展性 (SPI 多种序列化⽅式 多种协议)
    • 丰富的服务治理能⼒
    • 超⼤规模集群实例⽔平扩展
  • 云原生友好

    • 容器调度平台(Kubernetes)

      将服务的组织与注册交给底层容器平台,如 Kubernetes,这是更云原 ⽣的⽅式。

    • Service Mesh

      原有Mesh结构中通过Sidecar完成负载均衡、路由等操作,但是存在链路的性能损耗⼤,现有系统迁移繁琐等问题。 Dubbo3 引⼊Proxyless Mesh,直接和I控制⾯交互[istio]通信。集成 ServiceMesh更为⽅便,效率更高。

Dubbo3前言

代码结构及其术语解释

  1. provider 功能提供者
  2. consumer 功能调⽤者【功能消费者】
  3. commons-api 通⽤内容 entity service接口
  4. registry 注册中⼼
    1. 可选
    2. ⽤于管理provider集群

模块结构

开发步骤
  1. 开发commons-api 通⽤内容
  2. 开发provider 功能提供者
  3. 开发 consumer 功能调⽤者【功能消费者】
  4. 如需要注册中心,开发registry 注册中⼼

本专题所使用软件版本

JDK使用了两种JDK:JDK8和JDK17

Maven:3.8.7

Dubbo:3.2.0

JDK与Dubbo版本的关系
1. JDK8 与 Dubbo3.1.x以前的版本匹配,在使⽤Zookeeper注册作为注册中⼼时,消费者会出现节点已经存在的异常
	https://github.com/apache/dubbo/issues/11077
2. JDK17 与 Dubbo3.1.x之前的版本搭配使⽤会出现如下问题
	a. JDK9之后的深反射问题,需要通过JVM参数配置解决
        -Dio.netty.tryReflectionSetAccessible=true
        --add-opens
        java.base/jdk.internal.misc=ALL-UNNAMED
        --add-opens
        java.base/java.nio=ALL-UNNAMED
        --add-opens
        java.base/java.lang=ALL-UNNAMED
	b. Dubbo3.2.0.beat4以前的版本使⽤的是Spring5.2.x 不能⽀持 JDK17
		会产⽣如下异常
		Unsupported class file major version 61 【major 61 对应 17 】
		版本需要升级到Dubbo3.2.0.beat5以上版本

基于XML的Dubbo3程序开发

环境搭建

项目结构

父项目pom.xml的依赖

<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.22</version>
</dependency>

<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.32</version>
</dependency>

<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.2.9</version>
</dependency>

<dependency>
    <groupId>org.apache.dubbo</groupId>
    <artifactId>dubbo</artifactId>
    <version>3.2.0</version>
</dependency>
首先开发公共模块-api模块
实体entity
@Data
@ToString
@NoArgsConstructor
@AllArgsConstructor
public class User implements Serializable {
    private String name;
    private String password;
}
接口service
public interface UserService {
    public boolean login(String name,String password);
}

类文件目录

开发provider模块
在provider模块添加依赖
<dependencies>
    <dependency>
        <groupId>com.sjdwz</groupId>
        <artifactId>dubbo-01-api</artifactId>
        <version>1.0-SNAPSHOT</version>
    </dependency>
</dependencies>
实现接口
public class UserServiceImpl implements UserService{
    @Override
    public boolean login(String name, String password) {
        System.out.println("UserServiceImpl.login name "+name + " password "+password);
        return false;
    }
}
创建Spring配置文件,配置Dubbo相关内容使得UserServiceImpl可以跨虚拟机来调用

配置文件结构

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://dubbo.apache.org/schema/dubbo"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://dubbo.apache.org/schema/dubbo http://dubbo.apache.org/schema/dubbo/dubbo.xsd">

    <!-- 为dubbo起个名字,要做到唯一,可以被注册中心所管理 -->
    <dubbo:application name="dubbo-02-provider"/>

    <!-- 设置rpc相关的协议 使得可以网络通信 -->
    <dubbo:protocol name="dubbo" port="20880"/>

    <!-- 创建对象 -->
    <bean id="userService" class="com.sjdwz.service.UserServiceImpl"/>

    <!-- 发布dubbo服务 -->
    <dubbo:service interface="com.sjdwz.service.UserService" ref="userService"/>

</beans>
Spring工厂启动类

Spring工厂启动类

运行起来发现,会导出一个url

export url

dubbo://192.168.96.1:20880/com.sjdwz.service.UserService
开发consumer模块
引入api模块依赖
<dependencies>
    <dependency>
        <groupId>com.sjdwz</groupId>
        <artifactId>dubbo-01-api</artifactId>
        <version>1.0-SNAPSHOT</version>
    </dependency>
</dependencies>
创建Spring配置文件

配置文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://dubbo.apache.org/schema/dubbo"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://dubbo.apache.org/schema/dubbo http://dubbo.apache.org/schema/dubbo/dubbo.xsd">

    <!-- 配置dubbo服务名称 -->
    <dubbo:application name="dubbo-03-consuemer" />

    <!-- 获取远端服务
    url就是刚才导出的url
    -->
    <dubbo:reference interface="com.sjdwz.service.UserService" id="userService"
                     url="dubbo://192.168.96.1:20880/com.sjdwz.service.UserService"/>

</beans>
创建启动类

启动类

启动起来就可以看到消费端和生产端相应的输出。

注意

消费端会有一个异常

16:40:41.156 [main] ERROR org.apache.dubbo.qos.server.Server -  [DUBBO] qos-server can not bind localhost:22222, dubbo version: 3.2.0, current host: 192.168.96.1, error code: 7-4. This may be caused by , go to https://dubbo.apache.org/faq/7/4 to find instructions. 

问题产生的原因:
Qos=Quality of Service,qos是Dubbo的在线运维命令,可以对服务进⾏动态的配置、控制及查询,Dubboo2.5.8新版本重构了telnet(telnet是从Dubbo2.0.5开始⽀持的)模块,提供了新的telnet命令支持,新版本的telnet端⼝与dubbo协议的端⼝是不同的端⼝,默认为22222。正是因为这个问题:如果在⼀台服务器里面,启动provider是22222端⼝,⽽consumer启动时就会报错了。

xml解决方案

<dubbo:parameter key="qos.enable" value="true"/> <!--
是否开启在线运维命令 -->
<dubbo:parameter key="qos.accept.foreign.ip" value="false"/> <!--
不允许其他机器的访问 -->
<dubbo:parameter key="qos.port" value="33333"/> <!--
修改port-->

boot解决方案

dubbo.application.qos.enable=true
dubbo.application.qos.port=33333
dubbo.application.qos.accept.foreign.ip=false

细节补充

  1. 协议、端口
provider基于dubbo协议 默认的端⼝是20880
<dubbo:protocol name="dubbo" port="20880"/>
但是随着应⽤数量过⼤如果显示指定协议端⼝,会容易造成端⼝冲突所以建议按照如下写法设置
端⼝
<dubbo:protocol name="dubbo" port="-1"/>
  1. 应用程序运行过程浅析

    • 为什么provider提供了UserService的实现,而在另一个JVM中的consumer中可以调用?Consumer中调用的到底是什么?

      实际上调用的是远端UserServiceImpl的代理对象 Proxy

    • 代理的核心工作是什么?

      被consumer实际调用,通过代理对consumer屏蔽网络通信的过程(通信方式、协议、序列化),数据传递。

基于SpringBoot的方式使用Dubbo

SpringBoot应用Dubbo开发应用的核心思路分析

深度封装,把公⽤的配置放置到application.yml中,把个性的配置应⽤注解进⾏设置。

provider的处理

provider的处理

consumer的处理

consumer的处理

编码开发

provider模块

创建新的module

provider模块

再引入api模块和dubbo-starter

<dependency>
    <groupId>com.sjdwz</groupId>
    <artifactId>dubbo-01-api</artifactId>
    <version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
    <groupId>org.apache.dubbo</groupId>
    <artifactId>dubbo-spring-boot-starter</artifactId>
    <version>3.2.0</version>
</dependency>

创建applicaion.yml;将公共的配置放到这里面:

applicaion.yml

个性化的配置使用注解来完成;

DubboService注解

启动类上加**@EnableDubbo**注解:

启动类

启动日志

consumer模块

consumer模块

再引入api模块和dubbo-starter

<dependency>
    <groupId>com.sjdwz</groupId>
    <artifactId>dubbo-01-api</artifactId>
    <version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
    <groupId>org.apache.dubbo</groupId>
    <artifactId>dubbo-spring-boot-starter</artifactId>
    <version>3.2.0</version>
</dependency>

创建applicaion.yml;将公共的配置放到这里面:

applicaion.yml

在启动类中加上注解

启动类

在测试类中进行测试:

@SpringBootTest
class Dubbo05BootConsumerApplicationTests {

	//url是刚才输出的url
    @DubboReference(url = "dubbo://192.168.96.1:20880/com.sjdwz.service.UserService")
    private UserService userService;

    @Test
    public void test1() {
        boolean ret = userService.login("sjdwz", "123456");
        System.out.println("ret = " + ret);
    }
}

输出

@EnableDubbo注解的作用

  1. @EnableDubbo ⽤于扫描@DubboService,并把对应的对象实例化、发布成RPC服务。扫描的路径:应⽤这个注解的类(启动类)所在的包及其子包。
  2. 如果@DubboService注解修饰的类没有放到@EnableDubbo注解修饰类当前包及其⼦包,还希望能够扫描到它该如何处理?
    可以通过@DubboComponentScan(basePackages ={“org.sjdwz.service”}),显示的指定扫描的路径
  3. yml进⾏配置扫描@DubboService 并把对应的对象实例化,发布成RPC服务。
    dubbo.scan.base-packages 等同于 @EnableDubbo

@DubboService注解的作用

  1. 应⽤@DubboService注解修饰类型,SpringBoot会创建这个类型的对象,并发布成Dubbo服务。
  2. @DubboService 等同于 @Component(@Service) @Bean注解的创建对象的作⽤。
    通过源码SingletonObjects可以验证
  3. @DubboService
    a. 创建对象 等同于 @Component(@Service) @Bean
    b. 发布成RPC服务
  4. 后续开发过程中如果考虑兼容性,建议实现类不仅仅要加⼊@DubboService注解,同时也要加⼊@Service注解

@DubboReference注解的作用

  1. 在Consumer端,通过@DubboReference,注⼊远端服务的代理对象。
  2. @DubboReference类似于原始Spring开发中@Autowired注解的作⽤。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: Spring Boot可以很方便地与Dubbo和Nacos进行整合Dubbo是一个高性能的分布式服务框架,可以实现服务的注册、发现、调用和负载均衡等功能。Nacos是一个开源的服务发现和配置管理平台,可以实现服务的注册、发现、配置和动态路由等功能。 在Spring Boot中,可以通过使用Dubbo的Spring Boot Starter和Nacos的Spring Cloud Starter来实现对Dubbo和Nacos的整合。具体步骤如下: 1. 引入Dubbo和Nacos的Spring Boot Starter依赖: ```xml <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>2.7.8</version> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>2.2.5.RELEASE</version> </dependency> ``` 2. 配置Dubbo和Nacos的相关属性: ```yaml # Dubbo配置 dubbo: application: name: dubbo-provider registry: address: nacos://localhost:8848 protocol: name: dubbo port: 20880 scan: base-packages: com.example.dubbo.provider.service # Nacos配置 spring: cloud: nacos: discovery: server-addr: localhost:8848 ``` 3. 编写Dubbo服务提供者和消费者: ```java // 服务提供者 @Service public class HelloServiceImpl implements HelloService { @Override public String sayHello(String name) { return "Hello, " + name; } } // 服务消费者 @RestController public class HelloController { @Reference private HelloService helloService; @GetMapping("/hello") public String hello(@RequestParam String name) { return helloService.sayHello(name); } } ``` 4. 启动应用程序,Dubbo服务提供者会自动注册到Nacos中,Dubbo服务消费者会自动从Nacos中发现Dubbo服务提供者。 以上就是Spring Boot整合Dubbo和Nacos的基本步骤。通过这种方式,可以快速搭建分布式服务架构,实现服务的注册、发现、调用和负载均衡等功能。 ### 回答2: Spring Boot是现今最为流行的一款轻量级开发框架,其提供了非常方便快捷的开发方式,同时也提供了良好的集成支持。因此,许多人选择整合Dubbo和Nacos到Spring Boot中进行分布式系统开发Dubbo是阿里巴巴开源的一款高性能的RPC框架,它可以轻松解决分布式系统的服务调用问题。而Nacos则是阿里巴巴开源的一款注册中心和配置中心产品,它可以提供服务发现和配置管理的功能。 将Dubbo和Nacos整合到Spring Boot中,可以极大地简化分布式系统开发的流程,也可以提高系统的可用性和性能。下面分享一下整合Dubbo和Nacos的步骤。 1. 添加依赖 在pom.xml文件中添加Dubbo和Nacos的依赖,如下: <!-- Dubbo 依赖 --> <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> </dependency> <!-- Nacos 依赖 --> <dependency> <groupId>com.alibaba.nacos</groupId> <artifactId>nacos-client</artifactId> </dependency> 2. 配置Dubbo和Nacos 在application.yml文件中配置Dubbo和Nacos的相关信息,如下: # Dubbo 配置 dubbo: application: name: dubbo-demo-consumer registry: protocol: nacos address: localhost:8848 protocol: name: dubbo port: -1 consumer: check: false # Nacos 配置 spring: cloud: nacos: discovery: server-addr: localhost:8848 3. 编写服务 编写服务接口和实现类,如下: // 服务接口 public interface HelloService { String sayHello(String name); } // 服务实现类 @Service public class HelloServiceImpl implements HelloService { @Override public String sayHello(String name) { return "Hello, " + name + "!"; } } 4. 注册服务 使用@DubboService注解将服务注册到Dubbo中,如下: @Service @DubboService public class HelloServiceImpl implements HelloService { @Override public String sayHello(String name) { return "Hello, " + name + "!"; } } 5. 调用服务 使用@Reference注解注入Dubbo服务实例,并调用服务,如下: @RestController public class HelloController { @Reference private HelloService helloService; @GetMapping("/hello") public String hello(@RequestParam String name) { return helloService.sayHello(name); } } 6. 运行应用 启动Spring Boot应用,即可通过http://localhost:8080/hello访问服务。 总结 通过上述步骤,我们可以轻松地将Dubbo和Nacos整合到Spring Boot中,从而实现分布式系统开发,提高系统的可用性和性能。虽然配置比较繁琐,但整体上来看还是比较简单易用的,也是目前比较推荐的开发方式之一。 ### 回答3: Spring Boot整合Dubbo和Nacos可以实现分布式微服务的搭建,下面我就给大家详细介绍一下。 1. Dubbo简介 Dubbo是阿里巴巴开源的一款高性能、轻量级的分布式微服务框架,可以为各种应用提供高性能的RPC通信和服务治理能力。Dubbo的核心思想是SOA(面向服务架构)和RPC(远程过程调用),它支持多协议、多语言、多注册中心和多负载均衡策略。 2. Nacos简介 Nacos是阿里巴巴开源的一款注册中心和配置中心,可以实现微服务的注册和发现、动态配置管理、服务路由和流量控制等功能。 3. Spring Boot整合Dubbo和Nacos 首先,需要在pom.xml文件中添加Dubbo和Nacos相关的依赖,可以使用Maven的依赖管理功能自动下载。 然后,在Spring Boot的配置文件application.properties(或者application.yml)中添加Dubbo和Nacos的相关配置信息,例如Dubbo的协议、端口号、服务名称等,Nacos的注册中心地址和命名空间等。 接下来,在Spring Boot中定义Dubbo的服务接口和实现类,并将其注册到Nacos的服务中心中。 最后,启动Spring Boot应用程序,Dubbo和Nacos会自动从Nacos注册中心发现可用的服务,并对外提供服务,从而实现微服务的分布式系统架构。 总结 通过上述步骤,我们可以轻松地实现Spring Boot整合Dubbo和Nacos,实现分布式微服务的搭建和服务治理。这种方案可以大大提高应用程序的性能和可伸缩性,同时可以实现系统的高可用和容错能力。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

随机的未知

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

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

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

打赏作者

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

抵扣说明:

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

余额充值