• SpringBoot整合ActiveMQ 生产者---消费者


    一. 安装ActiveMQ

         http://activemq.apache.org/download.html

         bin目录结构如下:

         如果我们是32位的机器,就双击win32目录下的activemq.bat,如果是64位机器,则双击win64目录下的activemq.bat,运行结果如下

      

    启动成功!成功之后在浏览器输入http://127.0.0.1:8161/地址,可以看到ActiveMQ的管理页面,用户名和密码默认都是admin,如下:

    二. 示例

    JMS(ActiveMQ)依赖

      pom.xml

        <dependency>
          <groupId>org.springframework.boot</groupId>
          <artifactId>spring-boot-starter-activemq</artifactId>
        </dependency>

     application.properties

    # activemq
    spring.activemq.broker-url=tcp://localhost:61616
    spring.activemq.user=admin
    spring.activemq.password=admin
    #默认为true表示使用内存的activeMQ,不需要安装activeMQ server
    spring.activemq.in-memory=false

    #如果此处设置为true,需要加如下的依赖包 <groupId>org.apache.activemq</groupId>
    # <artifactId>activemq-pool</artifactId> ,否则会自动配置失败,报JmsMessagingTemplate注入失败
    spring.activemq.pool.enabled=false

    在启动类中使用异步消息服务@EnableJms注解

    @EnableJms
    @SpringBootApplication
    public class SpringbootActiveMqApplication {

    public static void main(String[] args) {
    SpringApplication.run(SpringbootActiveMqApplication.class, args);
    }
    }

    编写消息生产者

    package com.shyroke.jms;

    import javax.jms.Destination;

    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.jms.core.JmsMessagingTemplate;
    import org.springframework.stereotype.Service;

    @Service("producer")
    public class Producer {
    @Autowired // 也可以注入JmsTemplate,JmsMessagingTemplate对JmsTemplate进行了封装
    private JmsMessagingTemplate jmsTemplate;

    // 发送消息,destination是发送到的队列,message是待发送的消息
    public void sendMessage(Destination destination, final String message) {
    jmsTemplate.convertAndSend(destination, message);
    }
    }

    编写两个消费者

    package com.shyroke.jms;

    import org.springframework.jms.annotation.JmsListener;
    import org.springframework.stereotype.Component;

    @Component
    public class Consumer {
    // 使用JmsListener配置消费者监听的队列,其中text是接收到的消息

    //http://127.0.0.1:8161  新建Queue:Firstqueue
    @JmsListener(destination = "Firstqueue")
    public void receiveQueue(String text) {
    System.out.println("Consumer收到的报文为:"+text);
    System.out.println("=================");
    }
    }

    测试

    package com.shyroke;

    import javax.jms.Destination;

    import org.apache.activemq.command.ActiveMQQueue;
    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.shyroke.jms.Producer;

    @RunWith(SpringRunner.class)
    @SpringBootTest(classes=SpringbootActiveMqApplication.class)
    public class SpringbootActiveMqApplicationTests {

    @Autowired
    private Producer producer;

    @Test
    public void contextLoads() {
    //http://127.0.0.1:8161  新建Queue:Firstqueue
    Destination destination=new ActiveMQQueue("Firstqueue");

    for(int i=0; i<5; i++){
    producer.sendMessage(destination, "生产者发送了消息"+i);
    }


    }

    }

    • 结果

  • 相关阅读:
    转:yum和aptget用法及区别
    APT upgrade 和 distupgrade 的差別
    flickr api 入门教程
    查看FileZila 快速连接密码
    Freemium模式
    asp.net 开发环境搭建
    flickr api authentication
    转:虚拟机VirtualBox中Ubuntu无法全屏解决方法
    转:网页设计中的默认字体样式详解
    Attempted to read or write protected memory. This is often an indication that other memory is corrupt.
  • 原文地址:https://www.cnblogs.com/smallfa/p/12360227.html
Copyright © 2020-2023  润新知