带着新人学springboot的应用07(springboot+RabbitMQ 下)
说一两句废话,强烈推荐各位小伙伴空闲时候也可以写写自己的博客!不管水平高低,不管写的怎么样,不要觉得写不好或者水平不够就不写了(咳,我以前就是这样的想法。。。自我反省!)。
但是开始写博客之后,你会发现很多你以为自己会的东西其实你并不会,然后你会经常在头脑中不断的搜索有关的片段,或者去别的大神博客里到处找有关的资料,最后领悟了属于自己的东西!然后再写出来和别人分享,别人也会给你点意见,你也会慢慢的改进。这不就是学习+复习+巩固+创新+分享+改进的这么的一个过程吗?
以前看过曹雪芹的红楼梦,让我印象最深刻的就是开篇第一回两句诗:“都云作者痴,谁解其中味?”
自从写博客之后,我信了一句话:写博客的好处谁写谁知道!
嘿嘿嘿,又在瞎说废话了,回归正题。
上一节手动实现了RabbitMQ,要自己去点点点创建交换器、队列,然后还要慢慢的绑定,那,能不能用程序去实现啊! 然后程序自己监听,比如有一个监听器直接监听animal队列,只要有消息丢到animal队列中,监听器就会直接从队列中取数据放到java代码中,反序列化成一个对象,然后我们就能快乐的使用这个对象了。
这一节我们就用springboot简单整合RabbitMQ,看看到底怎么用。
1.搭建环境
创建一个springboot项目,RabbitMQ+WEB+版本1.5.17


2.RabbitMQ的简单测试(可视化+代码结合使用)
注意,这里代码内部导入的很多类一定要是amqp包下的
还记得上节最后说了一个xxxTemplate吗?这个模板就是RabbitTemplate,这个模板建立起来java程序操作RabbitMQ的桥梁,就像电视机和遥控器之间的关系。
我先来说一种简单的方式,就是交换器和队列我们用可视化页面去创建,用鼠标点点点,跟上一节一样,然后我们只需要发送信息和设置监听取消息就ok了。
这是我上一节创建的交换器和队列,都绑定好了,这个就不多说了,上一节说的很清楚了


在springboot的配置文件中配置

在主配置类开启RabbitMQ消息中间件

随便写个类,注解用@Component或者@Service行, 最重要的是@RabbitListener注解,这个注解就相当于一个监听器,会一直监听指定队列的情况,只要这队列有什么异动,就会跑过去拿消息放到方法形参内。

用一个测试方法,模拟用户,我这里是往direct交换器发消息,RoutingKey为animal,最终应该是将消息发给了animal队列,然后被监听器监听,将消息放入形参Message中。

好了,配置完成,可以使用了。
其中要注意RabbitTemplate模板的使用方法(这个模板可以自动注入,原理后面大概看一下),自己可以查查资料, 可以自己试试每个方法。
然后先运行springboot应用,没输出;
运行测试方法模拟用户向RabbitMQ发消息,控制台打印消息,成功。

上面MyService中的方法形参是Message(试试Map行不行啊,我没试过...),但是有的时候用对象比较方便,于是我们可以测试用对象接受数据



运行后结果为:

由此可见,可以直接从RabbitMQ中反序列化出对象。所以从队列中取出消息,你可以直接诶用Message对象,好处是可以不用在意数据的类型,你还可以取到消息头的一些信息,但是你得到数据还需要进一步处理才能变成对象。
当然,如果你知道队列中数据的类型的话你可以直接用该类去接收数据,这样比较方便,后续用起来可以直接用。
3.用代码创建交换器和队列
上面大概就介绍完了RabbitMQ的基本用法,但是就有的人说用可视化工具多lower啊,我是高手,我就要用代码创建交换器和队列,并且进行绑定。
其实有时候还真有这样的需求,需要用代码临时创建一个交换器和队列,所以无论是为了体现出自己水平高深还是为了满足一些需求,我们都要学会用java代码实现创建交换器和队列,并进行绑定。
下面我们就来试试创建一个direct类型的交换器,名字叫"java-direct",再创建一个叫”java.queue“的队列,然后将这两个绑定,BindingKey为”java.queue“。
我们会用到一个类amqpAdmin,这个类看名字就知道是个很了不得的类,这个就相当于RabbitMQ管理员的角色。可以删除和创建RabbitMQ里的组件,declarexxx是创建组件,deletexxx是删除组件
其中,druable表示持久化(这里我设置队列持久化),arguement表示一些消息头参数,是一个map,用到的时候再看吧!

然后运行这个测试方法,打开RabbitMQ可视化工具,可以看到如下结果:



后面的用法我就不用多说了,和上面一样,该监听监听,该怎么做就怎么做,不过可以试试指定其他的key测试测试啊!
4.消息转化器
还记得radis中的那个存到redis中的数据,我们看不懂吗?这也就是所谓的乱码,因为默认用jdk序列化的嘛!
在RabbitMQ中也有类似的情况,假如我们RabbitMQ中的队列中消息由于某种原因卡住了,我们要用可视化工具看看这些数据是些什么鬼,但是我们看到的是下图这样的:
注:这里队列中数据我用的是map,才能看到乱码!如果用对象,这里什么也看不到。

这是因为那个RabbitTemplate默认发消息会用一个消息转换器,把我们要发送的消息换一种形态,但是这种形态不利于我们观察,于是我们就自己定义一个消息转换器,转成json形态,我们在可视化工具里就看得懂了。

然后我们看看可视化里的数据(这个时候map和对象都行,我用对象测试):

5.大概看看RabbitMQ的自动配置类
其实原理没什么好说的,和以前的套路一样,找自动配置类。
对了,很多小伙伴用springboot每整合一个新框架的时候,你要看一下这个新框架的基本配置,应该要知道首先就去对应的自动配置类里面找吧!
但是,也有很多人可能会说:特么的,这么多自动配置类,我怎么知道去哪里找啊,再说了,这个类名字这么长,我也记不住啊!
那我稍微提一下就以我们这个RabbitMQ为例:首先我们导入了RabbitMQ依赖,我们就能在jar包那里找到RabbitMQ或者amqp相关的东西(大家应该知道amqp和RabbitMQ之间的关系吧!其实就类似接口和实现类的关系)------------->然而并没有找到spring.factories文件,说明自动配置类应该是springboot自己就有的,我们可以到那个自动配置类的spring.factories中去看看

或者你也可以去下图这个路径看看(习惯了你都不用这样找,直接ctrl+N,然后查找“新框架的名字+AutoConfiguration”,大概就能找到)

自动配置类就找到了,一般自动配置类都会跟xxxProperties类放在一起,方便我们在配置文件控制参数,所以想要看看所有的能在配置文件配的参数,直接打开这个xxxProperties类,看看有什么属性就ok了。
然后打开自动配置类,看到这里

也可以打开RabbitTemplate,看看默认消息转换器是哪个,用什么规则去序列化消息的。

点进去看看具体的序列化规则


这个消息转换器其实也就是这样,我们再来继续看看自动配置类里面


不多说了,大概的看看就够了,消息中间件之RabbitMQ就说这么多东西吧!给新手一个入门,也许其中很多东西说的不准确啊,那也没办法,我水平就这样啊。。。不过很多细节还是要自己多练习啊,试试那个RabbitTemplate模板的很多方法,AmqpAdmin也有很多的方法;消息转换器的一些知识还需要自己去查查啊。。。。
咳,突然越写就越觉得还有很多东西都没说,很多细节问题!就这样吧,下一节我看看能说点什么新的东西。。
带着新人学springboot的应用07(springboot+RabbitMQ 下)的更多相关文章
- 带着新人学springboot的应用01(springboot+mybatis+缓存 上)
上一篇结束,第一次做一个这么长的系列,很多东西我也是没有说到,也许是还没有想到,哈哈哈,不过基本的东西还是说的差不多了的.假如以后碰到了不会的,随便查查资料配置一下就ok. 咳,还有大家如果把我前面的 ...
- 带着新人学springboot的应用04(springboot+mybatis+redis 完)
对于缓存也说了比较多了,大家对下图这一堆配置类现在应该有些很粗略的认识了(因为我也就很粗略的认识了一下,哈哈!),咳,那么我们怎么切换这个缓存呢?(就是不用springboot提供的默认的Simple ...
- 带着新人学springboot的应用13(springboot+热部署)
spring cloud我想做成一个系列,所以spring cloud+eureka后面会慢慢说到的,有兴趣的小伙伴可以关注后续! 这一节就简单说说springboot的热部署了(我一直想不通为什么叫 ...
- 带着新人学springboot的应用11(springboot+Dubbo+Zookeeper 上)
这次说个在大型项目比较常见的东西,就是分布式,分布式到底是个什么东西呢?概念太大,不好说,就像刚学javaee的人问你,什么是web啊,什么是spring啊等等,你可能觉得,这个东西我好像知道,但是用 ...
- 带着新人学springboot的应用10(springboot+定时任务+发邮件)
接上一节,环境一样,这次来说另外两个任务,一个是定时任务,一个是发邮件. 1.定时任务 定时任务可以设置精确到秒的准确时间去自动执行方法. 我要一个程序每一秒钟说一句:java小新人最帅 于是,我就写 ...
- 带着新人学springboot的应用09(springboot+异步任务)
本来想说说检索的,不过不知道什么鬼,下载ElasticSearch太慢了,还是放一下,后面有机会再补上!今天就说个简单的东西,来说说任务. 什么叫做任务呢?其实就是类中实现了一个什么功能的方法.常见的 ...
- 带着新人学springboot的应用08(springboot+jpa的整合)
这一节的内容比较简单,是springboot和jpa的简单整合,jpa默认使用hibernate,所以本质就是springboot和hibernate的整合. 说实话,听别人都说spring data ...
- 带着新人学springboot的应用06(springboot+RabbitMQ 中)
上一节说了这么多废话,看也看烦了,现在我们就来用鼠标点点点,来简单玩一下这个RabbitMQ. 注意:这一节还是不用敲什么代码,因为上一节我们设置了那个可视化工具,我们先用用可视化工具熟悉一下流程. ...
- 带着新人学springboot的应用05(springboot+RabbitMQ 上)
这次就来说说RabbitMQ,这个应该不陌生了,随便一查就知道这个是用来做消息队列的.(注意:这一节很多都是概念的东西,需要操作的比较少) 至于AMQP协议(Advanced Message Queu ...
随机推荐
- ELK logstash geoip值为空故障排查
首先我们用的是elasticsearch+kibana+logstash+filebeat 客户端filebeat收集日志后经过服务端logstash规则处理后储存到elasticsearch中,在k ...
- Run Keyword And Ignore Error,Run Keyword And Return Status,Run Keyword And Continue On Failure,Run Keyword And Expect Error,Wait Until Keyword Succeeds用法
*** Test Cases ***case1 #即使错误也继续执行,也不记录失败,且可以返回执行状态和错误信息 ${Run Keyword And Ignore Error status} ${st ...
- IOS8,IOS8.1等系统出现锁屏状态下WIFI断开问题的解决办法!
网络设备:TP-Link 300M无线路由器.DLINK 300M无线路由器.HP 300M无线路由器.APPLE AirPort无线路由器 终端:iphone5S+IOS8.1 故障现象:除appl ...
- NOIP2000普及组 T1计算器的改良
主要考字符串处理,把等式从等号中间断开,左边的区域为left,右边的区域为right. 开四个数组分别用来存储区域left和right中未知数的系数,区域left和right中的常数 先处理区域lef ...
- 利用jquery-barcode.js实现生成条形码
jquery-barcode官网 js下载地址-github 代码示范(官网上也有) <!DOCTYPE html> <html> <head> <meta ...
- VUE 一些环境配置
1. 安装 nrm 一键切换npm源 npm i nrm -g [安装命令工具] nrm ls [罗列出所有的源] nrm use taobao [使用 ...
- 常用的Tensor操作
常用的Tensor操作 1.通过tensor.view方法可以调整tensor的形状,但必须保证调整去前后元素总数一致.view不会修改自身的数据,返回新的tensor与原tensor共享内存,即更改 ...
- P2V后,VMWare ESX 上RedHat AS5网络不通问题的解决办法
现象: 机器在启动eth0后,可以ping通eth0的IP,但是很快就无法访问了. 原因: red hat 5.x 默认系统安装完成后为xen内核,那么xen内核引导启动后就会有虚拟网卡(vethx. ...
- Winsock编程基继承基础(网络对时程序)
#include <iostream> #include <stdio.h> #include "InitSock.h" using namespace s ...
- Python入门—文件读写
文件读写的基本流程: #1.打开文件#2.读写文件#3.关闭文件 f = open('文件读写',encoding='utf-8') #打开文件,并赋值给f,encoding='utf-8'让中文可以 ...