SpringBoot | 第十二章:RabbitMQ的集成和使用
2018-07-27 12:58
941 查看
前言
上节讲了缓存数据库
redis的使用,在实际工作中,一般上在系统或者应用间通信或者进行异步通知(登录后发送短信或者邮件等)时,都会使用消息队列进行解决此业务场景的解耦问题。这章节讲解下消息队列
RabbitMQ的集成和简单使用示例。
RabbitMQ介绍
SpringBoot集成RabbitMQ
总结
最后
老生常谈
RabbitMQ介绍
RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写,支持多种客户端,如:Python、Ruby、.NET、Java、JMS、C、PHP、ActionScript、XMPP、STOMP等,支持AJAX。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。
关于
AMQP(摘自互联网):
AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。消息中间件主要用于组件之间的解耦,消息的发送者无需知道消息使用者的存在,反之亦然。 AMQP的主要特征是面向消息、队列、路由(包括点对点和发布/订阅)、可靠性、安全。
题外话:其实
Redis也有提供队列功能。但我觉得,
redis还是专门用在缓存方面吧。
SpringBoot集成RabbitMQ
0.老规矩,加入pom依赖,这已经是Springboot的套路了。
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency>
1.application.properties配置加入rabbitmq相关配置。
RabbitAutoConfiguration类是其自动加载配置类。
# rabbitmq相关配置 spring.rabbitmq.host=127.0.0.1 spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest
2.关于配置,以上两步就完成了(
Springboot真的太方便了,写代码都是愉悦的)。正常使用时,若作为一个消费者,我们会配置一个接收队列,这里为了示例,直接以最小配置来演示下。
配置一个名为
okong的队列
@Configuration public class RabbitConfig { /** * 定义一个名为:oKong 的队列 * @return */ @Bean public Queue okongQueue() { return new Queue("okong"); } }
配置队列处理类,这里的队列就是上面配置的队列名称。:
Consumer.java
@Component //@RabbitListener 监听 okong 队列 @RabbitListener(queues = "okong") @Slf4j public class Consumer { /** * @RabbitHandler 指定消息的处理方法 * @param message */ @RabbitHandler public void process(String message) { log.info("接收的消息为: {}", message); } }
编写消息发送类,这里直接写成api方法,方便调试。
DemoController.java
/** * 简单示例 发送和接收队列消息 * @author oKong * */ @RestController public class DemoController { //AmqpTemplate接口定义了发送和接收消息的基本操作,目前spring官方也只集成了Rabbitmq一个消息队列。。 @Autowired AmqpTemplate rabbitmqTemplate; @GetMapping("/send") public String send(String msg) { //发送消息 rabbitmqTemplate.convertAndSend("okong", msg); return "消息:" + msg + ",已发送"; } }
3.启动应用,正常配置成功,在
Rabbitmq的控制台,是可以看见连接对象的。说明已经正常启动了。
![](https://oscdn.geek-share.com/Uploads/Images/Content/201807/2f4f6d2c524c90fa5cdcdb89093f65a1.jpg)
4.访问:http://127.0.0.1:8080/send?msg=hello,rabbitmq, 在控制台就可以看见消费者已经消费到此条消息了:
2018-07-24 22:59:00.777 INFO 11424 --- [cTaskExecutor-1] c.l.l.springboot.chapter12.Consumer : 接收的消息为: hello,rabbitmq
控制台界面,在
Queues标签页,也可以查看到队列
okong的消息。
![](https://oscdn.geek-share.com/Uploads/Images/Content/201807/649d137b2dd847061c8e1ceabce01196.jpg)
总结
本章节主要是对
RabbitMQ的集成和简单使用进行了说明,对于高并发系统而言,消息队列是一个常见的解决方案了。比如实现异步消息的通知,实现消费者/生产者模式等。由于对
rabbitmq没有过多的了解,详细的用法及相关消息队列的知识,可自行搜索相关资料下,这里就不阐述了。前段时间买了本关于
RabbitMQ方面的书籍,等看完了,也希望能单独写一篇关于消息队列的文章,敬请期待!
最后
目前互联网上很多大佬都有
SpringBoot系列教程,如有雷同,请多多包涵了。本文是作者在电脑前一字一句敲的,每一步都是实践的。若文中有所错误之处,还望提出,谢谢。
老生常谈
个人QQ:499452441
微信公众号:
lqdevOps
![](https://oscdn.geek-share.com/Uploads/Images/Content/201808/912e2a04f2c86ab1f60c5091a68c33b3.jpg)
个人博客:https://blog.lqdev.cn
完整示例:chapter-12
原文地址:http://blog.lqdev.cn/2018/07/24/springboot/chapter-twelve/
关于在Docker下安装部署Rabbitmq,可点击Docker:安装部署RabbitMQ。
相关文章推荐
- spring boot / cloud (九) 使用rabbitmq消息中间件
- 使用maven创建一个spring-boot项目-集成springmvc
- SpringBoot | 第三十章:Spring-data-jpa的集成和使用
- Spring boot集成RabbitMQ的示例代码
- springboot-26-springboot 集成rabbitmq
- 使用Spring Boot集成FastDFS
- Spring Boot 中使用 RabbitMQ
- SpringBoot集成Rabbit使用TopicRabbit指定发送集合
- rabbitMQ与spring集成在项目中使用
- spring-boot 集成 rabbitmq
- Spring Boot(十三)RabbitMQ安装与集成
- Spring Boot 集成 RabbitMQ 实战
- jersey的简单介绍及与spring-boot的集成使用
- Spring Boot 集成RabbitMQ入门Demo
- spring boot 、springMVC环境集成百度ueditor富文本编辑器,使用七牛云存储图片
- Spring Boot 集成 RabbitMq 实战操作(二)
- spring-boot 集成mybatis配置使用
- Spring Boot教程(十)Spring Boot中使用RabbitMQ
- SpringBoot Testing集成使用文档
- springboot集成rabbitmq(一)