Skip to content

Commit 70514ce

Browse files
author
YunaiV
committed
增加 spring cloud bus rabbitmq 示例
1 parent 3ce7501 commit 70514ce

File tree

14 files changed

+320
-9
lines changed

14 files changed

+320
-9
lines changed

README.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -187,7 +187,7 @@
187187

188188
* [《芋道 Spring Cloud Alibaba 配置中心 Nacos 入门》](http://www.iocoder.cn/Spring-Cloud-Alibaba/Nacos-Config/?github) 对应 [labx-05](https://github.com/YunaiV/SpringBoot-Labs/tree/master/labx-05)
189189
* [《芋道 Spring Cloud 配置中心 Apollo 入门》](http://www.iocoder.cn/Spring-Cloud/Apollo/?github) 对应 [labx-09](https://github.com/YunaiV/SpringBoot-Labs/tree/master/labx-09)
190-
* [《芋道 Spring Cloud 配置中心 Spring Cloud Config 入门》](http://www.iocoder.cn/Spring-Cloud/Config/?github) 对应 [labx-12](https://github.com/YunaiV/SpringBoot-Labs/tree/master/labx-12)
190+
* [《芋道 Spring Cloud 配置中心 Spring Cloud Config 入门》](http://www.iocoder.cn/Spring-Cloud/Spring-Cloud-Config/?github) 对应 [labx-12](https://github.com/YunaiV/SpringBoot-Labs/tree/master/labx-12)
191191

192192
## 消息队列
193193

Original file line numberDiff line numberDiff line change
@@ -0,0 +1,64 @@
1+
<?xml version="1.0" encoding="UTF-8"?>
2+
<project xmlns="http://maven.apache.org/POM/4.0.0"
3+
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
4+
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
5+
<parent>
6+
<artifactId>labx-18</artifactId>
7+
<groupId>cn.iocoder.springboot.labs</groupId>
8+
<version>1.0-SNAPSHOT</version>
9+
</parent>
10+
<modelVersion>4.0.0</modelVersion>
11+
12+
<artifactId>labx-18-sc-bus-rabbitmq-demo-listener-actuator</artifactId>
13+
14+
<properties>
15+
<maven.compiler.target>1.8</maven.compiler.target>
16+
<maven.compiler.source>1.8</maven.compiler.source>
17+
<spring.boot.version>2.2.4.RELEASE</spring.boot.version>
18+
<spring.cloud.version>Hoxton.SR1</spring.cloud.version>
19+
</properties>
20+
21+
<!--
22+
引入 Spring Boot、Spring Cloud、Spring Cloud Alibaba 三者 BOM 文件,进行依赖版本的管理,防止不兼容。
23+
在 https://dwz.cn/mcLIfNKt 文章中,Spring Cloud Alibaba 开发团队推荐了三者的依赖关系
24+
-->
25+
<dependencyManagement>
26+
<dependencies>
27+
<dependency>
28+
<groupId>org.springframework.boot</groupId>
29+
<artifactId>spring-boot-starter-parent</artifactId>
30+
<version>${spring.boot.version}</version>
31+
<type>pom</type>
32+
<scope>import</scope>
33+
</dependency>
34+
<dependency>
35+
<groupId>org.springframework.cloud</groupId>
36+
<artifactId>spring-cloud-dependencies</artifactId>
37+
<version>${spring.cloud.version}</version>
38+
<type>pom</type>
39+
<scope>import</scope>
40+
</dependency>
41+
</dependencies>
42+
</dependencyManagement>
43+
44+
<dependencies>
45+
<!-- 引入 SpringMVC 相关依赖,并实现对其的自动配置 -->
46+
<dependency>
47+
<groupId>org.springframework.boot</groupId>
48+
<artifactId>spring-boot-starter-web</artifactId>
49+
</dependency>
50+
51+
<!-- 引入基于 RabbitMQ 的 Spring Cloud Bus 的实现的依赖,并实现对其的自动配置 -->
52+
<dependency>
53+
<groupId>org.springframework.cloud</groupId>
54+
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
55+
</dependency>
56+
57+
<!-- 实现对 Actuator 的自动化配置 -->
58+
<dependency>
59+
<groupId>org.springframework.boot</groupId>
60+
<artifactId>spring-boot-starter-actuator</artifactId>
61+
</dependency>
62+
</dependencies>
63+
64+
</project>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
package cn.iocoder.springcloud.labx18.listenerdemo;
2+
3+
import org.springframework.boot.SpringApplication;
4+
import org.springframework.boot.autoconfigure.SpringBootApplication;
5+
import org.springframework.cloud.bus.jackson.RemoteApplicationEventScan;
6+
7+
@SpringBootApplication
8+
@RemoteApplicationEventScan
9+
public class ListenerDemoApplication {
10+
11+
public static void main(String[] args) {
12+
SpringApplication.run(ListenerDemoApplication.class, args);
13+
}
14+
15+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
package cn.iocoder.springcloud.labx18.listenerdemo.event;
2+
3+
import org.springframework.cloud.bus.event.RemoteApplicationEvent;
4+
5+
/**
6+
* 用户注册事件
7+
*/
8+
public class UserRegisterEvent extends RemoteApplicationEvent {
9+
10+
/**
11+
* 用户名
12+
*/
13+
private String username;
14+
15+
public UserRegisterEvent() { // 序列化
16+
}
17+
18+
public UserRegisterEvent(Object source, String originService, String destinationService, String username) {
19+
super(source, originService);
20+
this.username = username;
21+
}
22+
23+
public String getUsername() {
24+
return username;
25+
}
26+
27+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
package cn.iocoder.springcloud.labx18.listenerdemo.listener;
2+
3+
import cn.iocoder.springcloud.labx18.listenerdemo.event.UserRegisterEvent;
4+
import org.slf4j.Logger;
5+
import org.slf4j.LoggerFactory;
6+
import org.springframework.context.ApplicationListener;
7+
import org.springframework.stereotype.Component;
8+
9+
/**
10+
* 用户注册事件的监听器
11+
*/
12+
@Component
13+
public class UserRegisterListener implements ApplicationListener<UserRegisterEvent> {
14+
15+
private Logger logger = LoggerFactory.getLogger(getClass());
16+
17+
@Override
18+
public void onApplicationEvent(UserRegisterEvent event) {
19+
logger.info("[onApplicationEvent][监听到用户({}) 注册]", event.getUsername());
20+
}
21+
22+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,20 @@
1+
spring:
2+
application:
3+
name: listener-demo
4+
5+
# RabbitMQ 相关配置项
6+
rabbitmq:
7+
host: localhost
8+
port: 5672
9+
username: guest
10+
password: guest
11+
12+
server:
13+
port: 18080 # 随机端口,方便启动多个消费者
14+
15+
management:
16+
endpoints:
17+
# Actuator HTTP 配置项,对应 WebEndpointProperties 配置类
18+
web:
19+
exposure:
20+
include: '*' # 需要开放的端点。默认值只打开 health 和 info 两个端点。通过设置 * ,可以开放所有端点。
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,64 @@
1+
<?xml version="1.0" encoding="UTF-8"?>
2+
<project xmlns="http://maven.apache.org/POM/4.0.0"
3+
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
4+
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
5+
<parent>
6+
<artifactId>labx-18</artifactId>
7+
<groupId>cn.iocoder.springboot.labs</groupId>
8+
<version>1.0-SNAPSHOT</version>
9+
</parent>
10+
<modelVersion>4.0.0</modelVersion>
11+
12+
<artifactId>labx-18-sc-bus-rabbitmq-demo-publisher-actuator</artifactId>
13+
14+
<properties>
15+
<maven.compiler.target>1.8</maven.compiler.target>
16+
<maven.compiler.source>1.8</maven.compiler.source>
17+
<spring.boot.version>2.2.4.RELEASE</spring.boot.version>
18+
<spring.cloud.version>Hoxton.SR1</spring.cloud.version>
19+
</properties>
20+
21+
<!--
22+
引入 Spring Boot、Spring Cloud、Spring Cloud Alibaba 三者 BOM 文件,进行依赖版本的管理,防止不兼容。
23+
在 https://dwz.cn/mcLIfNKt 文章中,Spring Cloud Alibaba 开发团队推荐了三者的依赖关系
24+
-->
25+
<dependencyManagement>
26+
<dependencies>
27+
<dependency>
28+
<groupId>org.springframework.boot</groupId>
29+
<artifactId>spring-boot-starter-parent</artifactId>
30+
<version>${spring.boot.version}</version>
31+
<type>pom</type>
32+
<scope>import</scope>
33+
</dependency>
34+
<dependency>
35+
<groupId>org.springframework.cloud</groupId>
36+
<artifactId>spring-cloud-dependencies</artifactId>
37+
<version>${spring.cloud.version}</version>
38+
<type>pom</type>
39+
<scope>import</scope>
40+
</dependency>
41+
</dependencies>
42+
</dependencyManagement>
43+
44+
<dependencies>
45+
<!-- 引入 SpringMVC 相关依赖,并实现对其的自动配置 -->
46+
<dependency>
47+
<groupId>org.springframework.boot</groupId>
48+
<artifactId>spring-boot-starter-web</artifactId>
49+
</dependency>
50+
51+
<!-- 引入基于 RabbitMQ 的 Spring Cloud Bus 的实现的依赖,并实现对其的自动配置 -->
52+
<dependency>
53+
<groupId>org.springframework.cloud</groupId>
54+
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
55+
</dependency>
56+
57+
<!-- 实现对 Actuator 的自动化配置 -->
58+
<dependency>
59+
<groupId>org.springframework.boot</groupId>
60+
<artifactId>spring-boot-starter-actuator</artifactId>
61+
</dependency>
62+
</dependencies>
63+
64+
</project>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
package cn.iocoder.springcloud.labx18.publisherdemo;
2+
3+
import org.springframework.boot.SpringApplication;
4+
import org.springframework.boot.autoconfigure.SpringBootApplication;
5+
6+
@SpringBootApplication
7+
//@RemoteApplicationEventScan
8+
public class PublisherDemoApplication {
9+
10+
public static void main(String[] args) {
11+
SpringApplication.run(PublisherDemoApplication.class, args);
12+
}
13+
14+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
package cn.iocoder.springcloud.labx18.publisherdemo.controller;
2+
3+
import cn.iocoder.springcloud.labx18.publisherdemo.event.UserRegisterEvent;
4+
import org.slf4j.Logger;
5+
import org.slf4j.LoggerFactory;
6+
import org.springframework.beans.factory.annotation.Autowired;
7+
import org.springframework.cloud.bus.ServiceMatcher;
8+
import org.springframework.context.ApplicationEventPublisher;
9+
import org.springframework.web.bind.annotation.GetMapping;
10+
import org.springframework.web.bind.annotation.RequestMapping;
11+
import org.springframework.web.bind.annotation.RestController;
12+
13+
@RestController
14+
@RequestMapping("/demo")
15+
public class DemoController {
16+
17+
private Logger logger = LoggerFactory.getLogger(getClass());
18+
19+
@Autowired
20+
private ApplicationEventPublisher applicationEventPublisher;
21+
22+
@Autowired
23+
private ServiceMatcher busServiceMatcher;
24+
25+
@GetMapping("/register")
26+
public String register(String username) {
27+
// ... 执行注册逻辑
28+
logger.info("[register][执行用户({}) 的注册逻辑]", username);
29+
30+
// ... 发布
31+
applicationEventPublisher.publishEvent(new UserRegisterEvent(this, busServiceMatcher.getServiceId(),
32+
null, username));
33+
return "success";
34+
}
35+
36+
37+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
package cn.iocoder.springcloud.labx18.publisherdemo.event;
2+
3+
import org.springframework.cloud.bus.event.RemoteApplicationEvent;
4+
5+
/**
6+
* 用户注册事件
7+
*/
8+
public class UserRegisterEvent extends RemoteApplicationEvent {
9+
10+
/**
11+
* 用户名
12+
*/
13+
private String username;
14+
15+
public UserRegisterEvent() { // 序列化
16+
}
17+
18+
public UserRegisterEvent(Object source, String originService, String destinationService, String username) {
19+
super(source, originService);
20+
this.username = username;
21+
}
22+
23+
public String getUsername() {
24+
return username;
25+
}
26+
27+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
spring:
2+
application:
3+
name: publisher-demo
4+
5+
# RabbitMQ 相关配置项
6+
rabbitmq:
7+
host: localhost
8+
port: 5672
9+
username: guest
10+
password: guest
11+
12+
management:
13+
endpoints:
14+
# Actuator HTTP 配置项,对应 WebEndpointProperties 配置类
15+
web:
16+
exposure:
17+
include: '*' # 需要开放的端点。默认值只打开 health 和 info 两个端点。通过设置 * ,可以开放所有端点。

labx-18/labx-18-sc-bus-rabbitmq-demo-publisher/src/main/java/cn/iocoder/springcloud/labx18/publisherdemo/controller/DemoController.java

+3-8
Original file line numberDiff line numberDiff line change
@@ -6,35 +6,30 @@
66
import org.springframework.beans.factory.annotation.Autowired;
77
import org.springframework.cloud.bus.ServiceMatcher;
88
import org.springframework.context.ApplicationEventPublisher;
9-
import org.springframework.context.ApplicationEventPublisherAware;
109
import org.springframework.web.bind.annotation.GetMapping;
1110
import org.springframework.web.bind.annotation.RequestMapping;
1211
import org.springframework.web.bind.annotation.RestController;
1312

1413
@RestController
1514
@RequestMapping("/demo")
16-
public class DemoController implements ApplicationEventPublisherAware {
15+
public class DemoController {
1716

1817
private Logger logger = LoggerFactory.getLogger(getClass());
1918

19+
@Autowired
2020
private ApplicationEventPublisher applicationEventPublisher;
2121

2222
@Autowired
2323
private ServiceMatcher busServiceMatcher;
2424

25-
@Override
26-
public void setApplicationEventPublisher(ApplicationEventPublisher applicationEventPublisher) {
27-
this.applicationEventPublisher = applicationEventPublisher;
28-
}
29-
3025
@GetMapping("/register")
3126
public String register(String username) {
3227
// ... 执行注册逻辑
3328
logger.info("[register][执行用户({}) 的注册逻辑]", username);
3429

3530
// ... 发布
3631
applicationEventPublisher.publishEvent(new UserRegisterEvent(this, busServiceMatcher.getServiceId(),
37-
"**", username));
32+
null, username));
3833
return "success";
3934
}
4035

labx-18/labx-18-sc-bus-rabbitmq-demo-publisher/src/main/resources/application.yml

+6
Original file line numberDiff line numberDiff line change
@@ -8,3 +8,9 @@ spring:
88
port: 5672
99
username: guest
1010
password: guest
11+
12+
# Bus 相关配置项,对应 BusProperties
13+
cloud:
14+
bus:
15+
enabled: true # 是否开启,默认为 true
16+
destination: springCloudBus # 目标消息队列,默认为 springCloudBus

labx-18/pom.xml

+3
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,9 @@
1414
<modules>
1515
<module>labx-18-sc-bus-rabbitmq-demo-publisher</module>
1616
<module>labx-18-sc-bus-rabbitmq-demo-listener</module>
17+
18+
<module>labx-18-sc-bus-rabbitmq-demo-listener-actuator</module>
19+
<module>labx-18-sc-bus-rabbitmq-demo-publisher-actuator</module>
1720
</modules>
1821

1922

0 commit comments

Comments
 (0)