dubbo简单使用

父类的pom

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>

<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>3.2.8</version>
</parent>

<groupId>com.yx</groupId>
<artifactId>dubbo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<name>dubbo</name>
<description>Demo project for Apache Dubbo</description>
<modules>
<module>provider</module>
<module>consumer</module>
</modules>
<properties>
<java.version>17</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<spring-boot.version>3.1.2</spring-boot.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>

<!-- Dubbo -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-bom</artifactId>
<version>3.2.6</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>3.2.6</version>
</dependency>
<!--哪个配置中心用哪个-->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-dependencies-zookeeper-curator5</artifactId>
<version>3.2.6</version>
<type>pom</type>
</dependency>
<!--<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-nacos-spring-boot-starter</artifactId>
</dependency>-->

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>


<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${spring-boot.version}</version>
<configuration>
<mainClass>com.yx.dubbo.DubboApplication</mainClass>
</configuration>
<executions>
<execution>
<id>repackage</id>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>

</project>

子类关系图

图片引用方法三

consumer的controller层调用provider的service层,consumer下同名的service层是用来防止编译错误的,没有实际用处

provider的service层,@DubboService类似于spring的@Service,只不过这个是注册到zookeeper或别的注册中心中

图片引用方法三

consumer的controller层,@DubboReference类似于@Autowired

图片引用方法三

application.yml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
server:
port: 8082 #不同的服务不同
dubbo:
application:
name: dubbo-springboot-demo-provider #不同的服务不同
protocol:
name: dubbo
port: -1
registry:
address: zookeeper://127.0.0.1:2181
timeout: 10000

#dubbo:
# application:
# name: demo-service # 服务名称
# registry:
# address: zookeeper://127.0.0.1:2181 # 注册中心地址,可以是 Zookeeper 或 Nacos 等
# protocol:
# name: dubbo # 协议类型,一般使用 dubbo
# port: 20880 # 服务端口 填-1就是自动分配
# threads: 200 # 线程池数量,控制并发能力
#
# # 消费者配置
# consumer:
# check: false # 是否进行消费方检查,通常设置为 false
# timeout: 5000 # 超时设置,单位为毫秒
#
# # 提供者配置
# provider:
# timeout: 5000 # 设置服务端超时时间,单位毫秒
# retries: 3 # 设置重试次数
# delay: 1000 # 启动延迟时间,单位毫秒

记得加启动注解

图片引用方法三