RabbitMQ的安装不在此赘述,想了解的可以参考:Spring Boot中使用RabbitMQ
1、新建一个spring-boot工程,本示例命名为:spring-boot-rabbitmq-demo
2、在pom.xml中引入amqp
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency>
3、在application.properties中配置rabbitmq
spring.application.name=spring-boot-rabbitmq-demo spring.rabbitmq.host=127.0.0.1 spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest spring.rabbitmq.listener.simple.concurrency=10
4、配置RabbitMQ的队列和消息转换器
package com.huatech.config; import org.springframework.amqp.core.Queue; import org.springframework.amqp.rabbit.config.SimpleRabbitListenerContainerFactory; import org.springframework.amqp.rabbit.connection.ConnectionFactory; import org.springframework.amqp.rabbit.core.RabbitTemplate; import org.springframework.amqp.support.converter.Jackson2JsonMessageConverter; import org.springframework.amqp.support.converter.MessageConverter; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class RabbitConfig { @Bean public Queue helloQueue() { return new Queue("user"); } @Bean public MessageConverter messageConverter() { return new Jackson2JsonMessageConverter(); } @Bean public SimpleRabbitListenerContainerFactory containerFactory(SimpleRabbitListenerContainerFactory factory) { factory.setMessageConverter(messageConverter()); return factory; } @Bean public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) { RabbitTemplate template = new RabbitTemplate(connectionFactory); template.setMessageConverter(messageConverter()); return template; } }
5、消息生产者UserSender
package com.huatech.rabbit; import java.util.Date; import org.springframework.amqp.rabbit.core.RabbitTemplate; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import com.huatech.domain.User; @Component public class UserSender { @Autowired private RabbitTemplate rabbitTemplate; public void send() { for (int i = 0; i < 100; i++) { User user = new User(); user.setCreateTime(new Date()); user.setEmail("lihua_java@163.com"); user.setId(11L); user.setRemark("remark"); user.setUsername("lihua"); System.out.println("Sender : " + user.toString()); this.rabbitTemplate.convertAndSend("user", user); } } }
6、消息消费者UserReceiver
package com.huatech.rabbit; import org.springframework.amqp.rabbit.annotation.RabbitHandler; import org.springframework.amqp.rabbit.annotation.RabbitListener; import org.springframework.stereotype.Component; import com.huatech.domain.User; @Component @RabbitListener(queues = "user", containerFactory = "containerFactory") public class UserReceiver { @RabbitHandler public void process(User user) { System.out.println("Receiver : " + user.toString()); } }
7、测试
package com.huatech; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; import com.huatech.rabbit.UserSender; @RunWith(SpringRunner.class) @SpringBootTest public class ApplicationTests { @Autowired private UserSender sender; @Test public void testUser() throws Exception { sender.send(); Thread.sleep(5000); } }
相关推荐
Spring Boot 集成各种框架 使用案例(spring-boot-rabbitmq、spring-boot-mail、spring-boot-thymeleaf、spring-boot-shiro)
Spring Boot作为Java开发中的轻量级框架,简化了配置和集成各种技术,包括RabbitMQ。本套教程将详细介绍如何在Spring Boot项目中整合RabbitMQ,实现高效的消息传递。 首先,我们需要在Spring Boot项目中引入...
spring-boot-examples-master示例程序,与各种框架集成,包括: dockercompose-springboot-mysql-nginx spring-boot-actuator spring-boot-banner spring-boot-docker spring-boot-elasticsearch spring-boot-...
IDEA 是一款常用的 Java 开发集成环境,对于 Spring Boot 项目的支持非常完善,可以方便地创建、运行和调试应用。你可能已经在 IDEA 中配置了 Spring Boot 的运行配置,通过点击绿色的运行按钮启动项目,然后通过...
在这个名为 "spring-boot-examples.zip" 的压缩包中,包含了多个 Spring Boot 的示例项目,如 spring-boot-shiro、spring-boot-redis、spring-boot-web 和 spring-boot-rabbitmq,这些都是 Spring Boot 集成其他流行...
- [spring-boot-rabbitmq](https://github.com/ityouknow/spring-boot-examples/tree/master/spring-boot-rabbitmq):Spring Boot 和 Rabbitmq 各种消息应用案例 - [spring-boot-scheduler]...
7. **消息队列集成**:Spring Boot 支持与 RabbitMQ 或 Kafka 等消息中间件的集成,实现异步处理和解耦。 8. **缓存**:可以集成 Redis 或 Hazelcast 进行分布式缓存,提高应用性能。 9. **安全**:Spring ...
13. **事件驱动和消息传递**:通过 Spring Integration 和 AMQP 支持消息队列(如 RabbitMQ、Kafka),实现异步通信和解耦。 以上只是部分核心概念,Spring Boot 还包括许多其他功能和特性,如邮件服务、缓存支持、...
本示例“spring-cloud-steam-rabbitmq-demo”将探讨如何使用Spring Cloud Stream与RabbitMQ进行集成,以构建一个高效、可靠的分布式系统。 Spring Cloud Stream 是一个框架,用于构建可复用的、松耦合的服务,这些...
Spring Boot集成rabbitMQ实现消息推送,rabbitMQ为异步消息处理提出了一个很好的解决方案,它是一个非常好用的消息中间件。主要解决当生产者大量产生数据时,消费者无法快速消费的问题。这个时候需要一个中间层,...
在"spring-boot-tutorials-master.zip"这个压缩包中,我们找到了一系列关于Spring Boot的实战示例,涵盖了多个关键组件和技术,如Dubbo、RabbitMQ、Swagger2、缓存管理和JSP。接下来,我们将深入探讨这些知识点。 1...
在“RabbitMQ-3.4.1安装文件”中,通常会包含安装程序或者源代码,以及相应的配置文件。在Linux环境下,通常通过编译源代码或者使用预编译的二进制包进行安装。在Windows下,可能提供的是一个安装向导。安装过程包括...
Spring Boot集成Spring Security,为应用程序提供安全控制。"spring-boot-mmanyexamples"可能包括了使用Spring Security实现用户认证、授权的示例。 8. **消息处理与RabbitMQ/ActiveMQ** Spring Boot支持集成消息...
通过这些示例,你可以深入理解Spring Boot如何与Spring框架的其他组件集成,以及如何利用其特性快速开发应用程序。对于初学者来说,这是一个很好的实践平台,可以学习到如何构建、配置和运行Spring Boot应用,同时也...
- 模块化:Spring Boot可以与其他Spring模块和第三方库无缝集成。 - 健康检查:提供健康检查API,方便监控应用状态。 - 可执行JAR:构建的JAR文件可以直接运行,无需额外的服务器环境。 3. **Spring Boot的核心...
"spring-boot 各种demo例子(最新)" 提供的是最新的 Spring Boot 集成示例代码,可以帮助开发者快速理解和学习如何在实际项目中应用 Spring Boot。下面我们将深入探讨这些 demo 示例中可能包含的关键知识点: 1. **...
它集成了大量常用的第三方库配置,如 JDBC、MongoDB、JPA、RabbitMQ、Quartz 等,让你可以“零”配置启动项目。在 `spring-boot-1.2.1.RELEASE.tar.gz` 这个压缩包中,包含的是 SpringBoot 的一个早期稳定版本,...
当我们谈论"spring-boot-rabbitmqq.zip"这个压缩包时,我们可以推断这是一份关于如何在Spring Boot项目中集成RabbitMQ以实现消息队列功能的教程或代码示例。 Spring Boot与RabbitMQ的整合主要涉及以下几个核心知识...