【中间件】MQ Rabbitmq 和spring整合

原创 2018年04月17日 21:58:50

例一、Xml配置文件

定义连接、定义了队列或交换机、可以设置Key、定义了消费者及路径

<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:rabbit="http://www.springframework.org/schema/rabbit"
    xsi:schemaLocation="http://www.springframework.org/schema/rabbit
    http://www.springframework.org/schema/rabbit/spring-rabbit-1.4.xsd
    http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans-4.0.xsd">

    <!-- 定义RabbitMQ的连接工厂 -->
    <rabbit:connection-factory id="connectionFactory"
        host="127.0.0.1" port="5672" username="mjx" password="mjx"
        virtual-host="/mjx" />

    <!-- 定义Rabbit模板,指定连接工厂以及定义exchange 放送到交换机  -->
    <!--模板:通过模板将消息发送到队列::将exchange改成queue  service注入-->
    <rabbit:template id="amqpTemplate" connection-factory="connectionFactory" exchange="fanoutExchange" />
    <!-- <rabbit:template id="amqpTemplate" connection-factory="connectionFactory"
        exchange="fanoutExchange" routing-key="foo.bar" /> -->

    <!-- MQ的管理,包括队列、交换器等 维护自动声明后的操作 -->
    <rabbit:admin connection-factory="connectionFactory" />

    <!-- 定义队列,自动声明 rabbit需要创建队列 -->
    <rabbit:queue name="myQueue" auto-declare="true"/>

    <!-- 定义交换器,自动声明:需要的时没有创建创建,有忽略  durable="true"持久化,保存在硬盘 -->
    <rabbit:fanout-exchange name="fanoutExchange" auto-declare="true" durable="true">
        <rabbit:bindings>
            <!--将队列绑定到交换机-->
            <rabbit:binding queue="myQueue"/>
        </rabbit:bindings>
    </rabbit:fanout-exchange>

<!--    <rabbit:topic-exchange name="myExchange">
    <rabbit:bindings>
        <rabbit:binding queue="myQueue" pattern="foo.*" />
    </rabbit:bindings>
    </rabbit:topic-exchange> -->

    <!-- 消费者foo:监听myqueue队列,监听-->
    <rabbit:listener-container connection-factory="connectionFactory">
        <!--有消息执行listen方法-->
        <rabbit:listener ref="foo" method="listen" queue-names="myQueue" />
    </rabbit:listener-container>

    <bean id="foo" class="cn.itcast.rabbitmq.spring.Foo" />

</beans>

消费者

public class Foo {
    //具体执行业务的方法
    public void listen(String foo) {
        System.out.println("消费者: " + foo);
    }
}

生产者:

public class SpringMain {
    public static void main(final String... args) throws Exception {
        AbstractApplicationContext ctx = new ClassPathXmlApplicationContext("classpath:spring/rabbitmq-context.xml");
        //RabbitMQ模板
        RabbitTemplate template = ctx.getBean(RabbitTemplate.class);
        //发送消息
        template.convertAndSend("Hello, world!");
        Thread.sleep(1000);// 休眠1秒
        ctx.destroy(); //容器销毁
    }
}

2@Autowired
Private RabbitTemplate rabbitTemplate;

Map<String ,Object> msg = new HashMap<String,Object>();
Msg.put("itemId",item.getId());
Msg.put("type","update");
Msg.put("date",system.currentTimeMillis());//当前时间戳
//发送消息
This.rabbitTemplate.convertAndSend("item.update",MAPPER.writeValueAsString(msg));//mapper序列化  抓异常,装饰

例子二:

Spring-rabbit:数据同步:通配符模式
service加入:使用的最低层导入;都用则公共;运行时在web层导入

servoce.xml

<!-- 定义RabbitMQ的连接工厂 -->
    <rabbit:connection-factory id="connectionFactory"
                               host="${rabbitmq.ip}" port="${rabbitmq.port}" username="${rabbitmq.username}"
                               password="${rabbitmq.password}"
                               virtual-host="${rabbitmq.vhost}"/>
    <!--管理-->
    <rabbit:admin connection-factory="connectionFactory"/>
    <!--交换机-->
    <rabbit:topic-exchange name="TAOTAO_ITEM_EXCHANAGE" auto-declare="true" durable="true"/>
    <!--定义模板-->

    <rabbit:template id="taotaoItemTemplate" connection-factory="connectionFactory" exchange="TAOTAO_ITEM_EXCHANAGE"/>

consumer.xml

<!-- 定义RabbitMQ的连接工厂 -->
    <rabbit:connection-factory id="connectionFactory"
                               host="${rabbitmq.ip}" port="${rabbitmq.port}" username="${rabbitmq.username}"
                               password="${rabbitmq.password}"
                               virtual-host="${rabbitmq.vhost}"/>
    <!--定义管理-->
    <rabbit:admin connection-factory="connectionFactory"/>
    <!--定义队列   没有交换机-->
    <rabbit:topic-exchange name="TAOTAO_WEB_ITEM_EXCHANAGE" auto-declare="true" durable="false"/>
    <!--定义消费者  没有模板 -->
    <bean id="itemMQHandler" class="itemMQHandler"/>
    <!--定义消费者监听队列-->
    <rabbit:listener-container connection-factory="connectionFactory">
        <rabbit:listener ref="itemMQHandler" method="excute" queue-names="TAOTAO_WEB_ITEM_EXCHANAGE"/>
    </rabbit:listener-container>

队列与交互机:

队列绑定交换机
   rabbitmq管理界面,低耦合、需要发邮件、申请才能绑定

MQ网页:

网页

User
        tags:角色;virtual host:数据库 斜杠开头 设置权限;

node:集群中的节点

端口:5672 java客户端,协议端口 ; 15672 管理工具端口 ; 25672 集群端口

Exchanges:交换机 D: 1、持久化(将数据保存在硬盘) 2、非持久化:保存在内存:读写快、数据丢失 durable=”true”

版权声明:欢迎大家的阅读,注明出处便可转载;学习过程中的笔记,厚着脸皮选了原创 https://blog.csdn.net/ma15732625261/article/details/79981588

消息中间件之RabbitMQ

一、什么是RabbitMQ? MQ是消费-生产者模型的一个典型的代表,一端往消息队列中不断写入消息,而另一端则可以读取或者订阅队列中 的消息。MQ和JMS类似,但不同的是JMS是SUN JAV...
  • Apeopl
  • Apeopl
  • 2017-03-14 16:07:37
  • 614

微服务消息中间件ActiveMQ,RabbitMQ,kafka等的技术选择

在微服务盛行的时代,系统的分布式,让我们广泛的运用消息中间件来进行系统间的数据交换,而且通过消息的方式,便于系统间异步解耦。我们在谈技术选型的时候,不能脱离业务空谈选型,每种消息中间件必定有其优点和不...
  • u010963948
  • u010963948
  • 2018-01-04 13:55:45
  • 543

【中间件】消息队列(一):RabbitMQ、ActiveMQ、Kafka和Redis

消息队列中间件
  • shandianke
  • shandianke
  • 2016-07-31 18:42:42
  • 6525

消息中间件RabbitMQ 的学习

 八.利用springAMQP实现异步消息队列的日志管理 摘要: 经过前段时间的学习和铺垫,已经对spring amqp有了大概的了解。俗话说学以致用,今天就利用springAMQP来完成一个...
  • suliqiang
  • suliqiang
  • 2018-01-03 13:52:02
  • 145

MQ消息中间件(工作+面试)

AMQP协议介绍 AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。 AMQP的主要特征...
  • Lunaqi
  • Lunaqi
  • 2017-11-13 09:51:21
  • 2698

rabbitMQ消息中间件

消息中间件 消息中间件一般两个功能,解耦和异步处理 异步处理: 有的时候,我们一个操作可能会耗时比较久,所以,并不会在主要业务流程里进行处理 比如,我们在删除一个用户的时候,可能会有很...
  • kunpeng90
  • kunpeng90
  • 2017-11-26 22:14:14
  • 263

RabbitMQ与spring集成,配置完整的生产者和消费者

RabbitMQ与AMQP协议详解可以看看这个  http://www.cnblogs.com/frankyou/p/5283539.html 下面是rabbitMQ和spring集成的配置,我配置...
  • xun573017588
  • xun573017588
  • 2017-08-11 16:16:56
  • 2800

使用rabbitmq消息中间件

###rabbitmq介绍: RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统。它可以用于大型软件系统各个模块之间的高效通信,支持高并发,支持可扩展。 ###amqp介绍...
  • myself8202
  • myself8202
  • 2017-08-31 14:53:19
  • 607

几款消息中间的调研

消息系统简介 本次主要调研业界使用广泛的两款消息队列——RabbitMQ, Kafka, 以及阿里云的提供的两个服务, MNS和ONS. RabbitMQ RabbitMQ 是使用Erl...
  • kobejayandy
  • kobejayandy
  • 2016-09-17 23:07:33
  • 1845

消息中间件(一)分布式系统事务一致性解决方案大对比,谁最好使?

在分布式系统中,同时满足“一致性”、“可用性”和“分区容错性”三者是不可能的。分布式系统的事务一致性是一个技术难题,各种解决方案孰优孰劣?在OLTP系统领域,我们在很多业务场景下都会面临事务一致性方面...
  • dreamsunday
  • dreamsunday
  • 2016-06-29 18:37:37
  • 14448
收藏助手
不良信息举报
您举报文章:【中间件】MQ Rabbitmq 和spring整合
举报原因:
原因补充:

(最多只允许输入30个字)