本文主要是介绍Spring Boot整合消息队列RabbitMQ的实现示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
《SpringBoot整合消息队列RabbitMQ的实现示例》本文主要介绍了SpringBoot整合消息队列RabbitMQ的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的...
RabbitMQ 简介与安装
1. RabbitMQ 简介
RabbitMQ 是一个开源的消息代理和队列服务器,基于 AMQP(高级消息队列协议)实现。它具有以下特点:
- 可靠性:支持持久化、传输确认、发布确认等机制,确保消息不丢失。
- 灵活性:支持多种消息模型,如点对点、发布 - 订阅等。
- 分布式:可以通过集群和镜像队列来实现高可用性和扩展性。
- 多语言支持:支持多种编程语言,如 Java、python、C# 等。
2. RabbitMQ 安装
以下以在 linux(Ubuntu)系统上安装 RabbitMQ 为例:
步骤 1:安装 ErlangRabbitMQ 是用 Erlang 语言编写的,因此需要先安装 Erlang。
# 添加http://www.chinasem.cn Erlang 仓库 wget https://packages.erlang-solutions.com/erlang-solutions_2.0_all.deb sudo dpkg -i erlang-solutions_2.0_all.deb sudo apt-get update # 安装 Erlang sudo apt-get install esl-erlang
步骤 2:安装 RabbitMQ
# 添加 RabbitMQ 仓库 echo "deb https://dl.bintray.com/rabbitmq/Debian $(lsb_release -scwww.chinasem.cn) main" | sudo tee /etc/apt/sources.list.d/bintray.rabbitmq.list wget -O- https://dl.bintray.com/rabbitmq/Keys/rabbitmq-release-signing-key.asc | sudo apt-key add - wget -O- https://www.rabbitmq.com/rabbitmq-release-signing-key.asc | sudo apt-key add - sudo apt-get update # 安装 RabbitMQ sudo apt-get install rabbitmq-server
步骤 3:启动 RabbitMQ 服务
sudo systemctl start rabbitmq-server
步骤 4:设置开机自启
sudo systemctl enable rabbitmq-server
步骤 5:启用管理界面
sudo rabbitmq-plugins enable rabbitmq_management
访问 http://localhost:15672
,使用默认用户名 guest
和密码 guest
登录管理界面。
Spring Boot 集成 RabbitMQ
1. 创建 Spring Boot 项目
可以使用 Spring Initializr(https://start.spring.io/)创建一个新的 Spring Boot 项目,添加以下依赖:
- Spring Web
- Spring AMQP
2. 配置 RabbitMQ
在 application.properties
或 application.yml
中配置 RabbitMQ 连接信息:
application.properties
spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest
application.yml
spring: rabbitmq: host: localhost port: 5672 username: guest password: guest
3. 定义消息队列和交换机
创建一个配置类来定义队列、交换机和绑定关系:
import org.springframework.amqp.core.Binding; import org.springframework.amqp.core.BindingBuilder; import org.springframework.amqp.core.DirectExchange; import org.springframework.amqp.core.Queue; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class RabbitMQConfig { public static final String QUEUE_NAME = "myQueue"; public static final String EXCHANGE_NAME = "myExchange"; public static final String ROUTING_KEY = "myRoutingKey"; @Bean public Queue queue() { return new Queue(QUEUE_NAME, true); } @Bean public DirectExchange exchange() { return new DirectExchange(EXCHANGE_NA编程ME); } @Bean public Binding binding(Queue queue, DirectExchange exchange) { return BindingBuilder.bind(queue).to(exchange).with(ROUTING_KEY); } }
4. 发送消息
创建一个消息发送者类:
import org.springframework.amqp.rabbit.core.RabbitTemplate; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @Service public class MessageSender { @Autowired prphpivate RabbitTemplate rabbitTemplate; public void sendMessage(String message) { rabbitTemplate.convertAndSend(RabbitMQConfig.EXCHANGE_NAME, RabbitMQConfig.ROUTING_KEY, message); } }
5. 接收消息
创建一个消息接收者类:
import org.springframework.amqp.rabbit.anno编程tation.RabbitListener; import org.springframework.stereotype.Service; @Service public class MessageReceiver { @RabbitListener(queues = RabbitMQConfig.QUEUE_NAME) public void receiveMessage(String message) { System.out.println("Received message: " + message); } }
6. 测试消息发送和接收
创建一个控制器来测试消息发送:
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; @RestController public class MessageController { @Autowired private MessageSender messageSender; @GetMapping("/send") public String sendMessage(@RequestParam String message) { messageSender.sendMessage(message); return "Message sent: " + message; } }
启动 Spring Boot 应用程序,访问 http://localhost:8080/send?message=Hello,RabbitMQ
,在控制台可以看到消息接收的输出。
通过以上步骤,就完成了 Spring Boot 与 RabbitMQ 的集成,实现了消息的发送和接收。
到此这篇关于Spring Boot整合消息队列RabbitMQ的实现示例的文章就介绍到这了,更多相关Spring Boot 消息队列RabbitMQ内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!
这篇关于Spring Boot整合消息队列RabbitMQ的实现示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!