RabbitMQ第四篇:Spring集成RabbitMQ
前面几篇讲解了如何使用rabbitMq,这一篇主要讲解spring集成rabbitmq。
首先引入配置文件org.springframework.amqp,如下
- <dependency>
- <groupId>org.springframework.amqp</groupId>
- <artifactId>spring-rabbit</artifactId>
- <version>1.6.0.RELEASE</version>
- </dependency>
一:配置消费者和生成者公共部分

- <rabbit:connection-factory id="connectionFactory" host="${rabbit.hosts}"
- port="${rabbit.port}" username="${rabbit.username}" password="${rabbit.password}" virtual-host="${rabbit.virtualHost}"
- channel-cache-size="50"/>
- <rabbit:admin connection-factory="connectionFactory"/>
- <!--定义消息队列-->
- <rabbit:queue name="spittle.alert.queue.1" durable="true" auto-delete="false"/>
- <rabbit:queue name="spittle.alert.queue.2" durable="true" auto-delete="false"/>
- <rabbit:queue name="spittle.alert.queue.3" durable="true" auto-delete="false"/>
- <!--绑定队列-->
- <rabbit:fanout-exchange id="spittle.fanout" name="spittle.fanout" durable="true">
- <rabbit:bindings>
- <rabbit:binding queue="spittle.alert.queue.1"></rabbit:binding>
- <rabbit:binding queue="spittle.alert.queue.2"></rabbit:binding>
- <rabbit:binding queue="spittle.alert.queue.3"></rabbit:binding>
- </rabbit:bindings>
- </rabbit:fanout-exchange>

二:配置生成者
- <import resource="amqp-share.xml"/>
- <!--创建消息队列模板-->
- <rabbit:template id="rabbitTemplate" connection-factory="connectionFactory"
- exchange="spittle.fanout" message-converter="jsonMessageConverter">
- </rabbit:template>
- <bean id="jsonMessageConverter" class="org.springframework.amqp.support.converter.JsonMessageConverter"></bean>
三:生产者程序

- public class Spittle implements Serializable {
- private Long id;
- private Spitter spitter;
- private String message;
- private Date postedTime;
- public Spittle(Long id, Spitter spitter, String message, Date postedTime) {
- this.id = id;
- this.spitter = spitter;
- this.message = message;
- this.postedTime = postedTime;
- }
- public Long getId() {
- return this.id;
- }
- public String getMessage() {
- return this.message;
- }
- public Date getPostedTime() {
- return this.postedTime;
- }
- public Spitter getSpitter() {
- return this.spitter;
- }
- }


- public class ProducerMain {
- public static void main(String[] args) throws Exception {
- ApplicationContext context = new ClassPathXmlApplicationContext("amqp/amqp-producer.xml");
- AmqpTemplate template = (AmqpTemplate) context.getBean("rabbitTemplate");
- for (int i = 0; i < 20; i++) {
- System.out.println("Sending message #" + i);
- Spittle spittle = new Spittle((long) i, null, "Hello world (" + i + ")", new Date());
- template.convertAndSend(spittle);
- Thread.sleep(5000);
- }
- System.out.println("Done!");
- }
- }

其中convertAndSend方法默认第一个参数是交换机名称,第二个参数是路由名称,第三个才是我们发送的数据,现在我们启动程序,效果如下
第四个:消费者程序
首先编写一个用于监听生产者发送信息的代码

- /**
- * Created by Administrator on 2016/11/18.
- */
- public class SpittleAlertHandler implements MessageListener {
- @Override
- public void onMessage(Message message) {
- try {
- String body=new String(message.getBody(),"UTF-8");
- System.out.println(body);
- } catch (UnsupportedEncodingException e) {
- e.printStackTrace();
- }
- }
- }

一定要注意实现MessageListener,我们只需要获取message的body即可,通过json来转换我们需要的程序(比如我们可以发送一个map,map存放方法和实体,这样我们可以通过反射来调用不同的程序来运行)。
下面我们配置消费者
- <import resource="amqp-share.xml"/>
- <rabbit:listener-container connection-factory="connectionFactory">
- <rabbit:listener ref="spittleListener" method="onMessage" queues="spittle.alert.queue.1,spittle.alert.queue.3,spittle.alert.queue.2"/>
- </rabbit:listener-container>
- <bean id="spittleListener" class="com.lp.summary.rabbitmq.impl.SpittleAlertHandler"/>
其中spittleListener是监听的程序,method是执行的方法,queues是我们监听的队列,多个队列可以逗号隔开(因为我们采用的是分发,所以三个队列获取的消息是相同的,这里为了简便我放在一个监听程序中了,其实我们可以写三个消费者,每个消费者监听一个队列)
现在只需要启动程序即可运行
- public class ConsumerMain {
- public static void main(String[] args) {
- ApplicationContext context = new ClassPathXmlApplicationContext("amqp/amqp-consumer.xml");
- }
- }
当然direct跟上面的情况差不多,只不过这个是根据路由匹配,先把数据发送到交换机,然后绑定路由和队列,通过交换机id和路由来找到队列,下面是一些主要的配置

- <rabbit:queue id="spring-test-queue1" durable="true" auto-delete="false" exclusive="false" name="spring-test-queue1"></rabbit:queue>
- <rabbit:queue name="spring-test-queue2" durable="true" auto-delete="false" exclusive="false"></rabbit:queue>
- <!--交换机定义-->
- <!--rabbit:direct-exchange:定义exchange模式为direct,
- 意思就是消息与一个特定的路由键完全匹配,才会转发。
- rabbit:binding:设置消息queue匹配的key-->
- <rabbit:direct-exchange name="${rabbit.exchange.direct}" durable="true" auto-delete="false" id="${rabbit.exchange.direct}">
- <rabbit:bindings>
- <rabbit:binding queue="spring-test-queue1" key="spring.test.queueKey1"/>
- <rabbit:binding queue="spring-test-queue2" key="spring.test.queueKey2"/>
- </rabbit:bindings>
- </rabbit:direct-exchange>
- <!--spring template声明-->
- <rabbit:template exchange="${rabbit.exchange.direct}" id="rabbitTemplate" connection-factory="connectionFactory"
- message-converter="jsonMessageConverter"></rabbit:template>
- <!--消息对象转成成json-->
- <bean id="jsonMessageConverter" class="org.springframework.amqp.support.converter.JsonMessageConverter"></bean>

下面是消费者监听配置
- <rabbit:listener-container connection-factory="connectionFactory" acknowledge="auto">
- <rabbit:listener queues="spring-test-queue1" method="onMessage" ref="queueListenter"></rabbit:listener>
- </rabbit:listener-container>
- <rabbit:listener-container connection-factory="connectionFactory" acknowledge="auto">
- <rabbit:listener queues="spring-test-queue2" method="onMessage" ref="queueListenter"></rabbit:listener>
- </rabbit:listener-container>
下面是程序
- public static void main(String[] args) {
- ApplicationContext context=new ClassPathXmlApplicationContext("applicationContext-rabbitmq-producer.xml");
- MQProducer mqProducer=(MQProducer) context.getBean("mqProducer");
- mqProducer.sendDateToQueue("spring.test.queueKey1","Hello World spring.test.queueKey1");
- mqProducer.sendDateToQueue("spring.test.queueKey2","Hello World spring.test.queueKey2");
- }
实际情况可能需要我们去分离消费者和生成者的程序。当然spring还有负载均衡的配置,这里就不多介绍了。
RabbitMQ第四篇:Spring集成RabbitMQ的更多相关文章
- rabbitMQ第五篇:Spring集成RabbitMQ
前面几篇讲解了如何使用rabbitMq,这一篇主要讲解spring集成rabbitmq. 首先引入配置文件org.springframework.amqp,如下 <dependency> ...
- spring集成rabbitMq(非springboot)
首先 , pom文件需要加入spring集成rabbitMq的依赖: <dependency> <groupId>org.springframework.amqp</gr ...
- RabbitMQ入门到进阶(Spring整合RabbitMQ&SpringBoot整合RabbitMQ)
1.MQ简介 MQ 全称为 Message Queue,是在消息的传输过程中保存消息的容器.多用于分布式系统 之间进行通信. 2.为什么要用 MQ 1.流量消峰 没使用MQ 使用了MQ 2.应用解耦 ...
- rabbitMQ第四篇:远程调用
前言:前面我们讲解的都是本地服务器,现在如果需要远程计算机上运行一个函数,等待结果.这就是一个不同的故事了,这种模式通常被称为远程过程调用或者RPC. 本章教程我们使用RabbitMQ搭建一个RPC系 ...
- rabbitMQ教程(四) spring整合rabbitMQ代码实例
一.开启rabbitMQ服务,导入MQ jar包和gson jar包(MQ默认的是jackson,但是效率不如Gson,所以我们用gson) 二.发送端配置,在spring配置文件中配置 <?x ...
- spring集成RabbitMQ配置文件详解(生产者和消费者)
1,首先引入配置文件org.springframework.amqp,如下: <dependency> <groupId>org.springframework.amqp< ...
- Spring 集成 RabbitMQ
pom.xml <dependency> <groupId>org.springframework.amqp</groupId> <artifactId> ...
- spring集成rabbitmq
https://www.cnblogs.com/nizuimeiabc1/p/9608763.html
- 从.Net到Java学习第四篇——spring boot+redis
从.Net到Java学习系列目录 “学习java已经十天,有时也怀念当初.net的经典,让这语言将你我相连,怀念你......”接上一篇,本篇使用到的框架redis.FastJSON. 环境准备 安装 ...
随机推荐
- linux 版本控制及rpm打包
版本控制 subversion:是一个自由/开源的版本控制系统,在subversion管理下,文件和目录可以超越时空subversion允许你数据恢复到早期版本,或者是检查数据修改历史许多人将版本控制 ...
- python环境jieba分词的安装
我的python环境是Anaconda3安装的,由于项目需要用到分词,使用jieba分词库,在此总结一下安装方法. 安装说明======= 代码对 Python 2/3 均兼容 * 全自动安装:`ea ...
- ubuntu 下命令行播放器mplayer 使用详解
ubuntu 下命令行播放器mplayer 使用详解 2011-01-02 21:00:42| 分类: Linux/Unix | 标签: |字号大中小 订阅 使用 MPlayer 播放媒体文件最简 ...
- FusionCharts报错收录
FusionCharts报错 1.错误一 DesignTimeError:#25081843 flash-chart render Error >>#25081843:IECompatib ...
- JDBC异常总结
1.异常一 (1)详情如下 com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Data source reje ...
- eclipse -解决Unhandled event loop exception GC overhead limit exceeded
今天第一次遇到这个问题, 拿出来和大家分享一下. 首先说明下我发现这个错误的过程, 看下面的三张图片 1,在本地weblogic发布项目的时候 2 , 等待一段时间, 出现以下错误 3 , 点击上 ...
- 四大组件之BroadcastReceiver基础
1. 系统广播 1.1 动态注册 (1)创建自定义接收器类继承自BroadcaseReceiver,实现onReceive()方法,对接收到的广播的逻辑处理就是写在这个函数中的. (2)实例化 ...
- 元素(WebElement)-----Selenium快速入门(三)
上一篇<元素定位-----Selenium快速入门(二)>说了,如何定位元素,本篇说说找到的元素(WebElement)该怎么用. WebElement常用方法: 返回值 方法名 说 ...
- 【BZOJ2002】弹飞绵羊(Link-Cut Tree)
[BZOJ2002]弹飞绵羊(Link-Cut Tree) 题面 题目描述 某天,Lostmonkey发明了一种超级弹力装置,为了在他的绵羊朋友面前显摆,他邀请小绵羊一起玩个游戏.游戏一开始,Lost ...
- 很简单的Java断点续传实现原理
原理解析 在开发当中,"断点续传"这种功能很实用和常见,听上去也是比较有"逼格"的感觉.所以通常我们都有兴趣去研究研究这种功能是如何实现的? 以Java来说,网 ...