springboot整合ActiveMQ(点对点+发布订阅)

生产者项目

<parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.1.RELEASE</version>
    </parent>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Finchley.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.11</version>
            <scope>test</scope>
        </dependency>

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

        <!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.62</version>
        </dependency>

    </dependencies>

application.yml

spring:
  activemq:
    #Mq连接通讯地址
    broker-url: tcp://127.0.0.1:61616
    #账号
    user: admin
    #密码
    password: admin

#自定义队列名称
my_queue: springboot-queue
server:
  port: 8080

config类

package com.vhukze.config;

import org.apache.activemq.command.ActiveMQQueue;
import org.apache.activemq.command.ActiveMQTopic;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.stereotype.Component;

import javax.jms.Queue;
import javax.jms.Topic;


@Component
public class ConfigQueue {

    @Value("${my_queue}")
    private String myQueue;

    //首先将队列注入到springboot容器中
    @Bean
    public Queue queue(){
        return new ActiveMQQueue(myQueue);
    }

//    //首先将主题注入到springboot容器中
//    @Bean
//    public Topic topic(){
//        return new ActiveMQTopic(myQueue);
//    }
}

生产者类

package com.vhukze.producer;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jms.core.JmsMessagingTemplate;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import javax.jms.Queue;
import javax.jms.Topic;

@Component
public class P2pProducer {
    @Autowired
    private JmsMessagingTemplate jmsMessagingTemplate;

    @Autowired
    private Queue queue;

//    @Autowired
//    private Topic topic;

    //每隔五秒向队列发送消息
    @Scheduled(fixedDelay = 5000)
    public void send(){
        String msg = System.currentTimeMillis() + "";
        jmsMessagingTemplate.convertAndSend(queue,msg);
//        jmsMessagingTemplate.convertAndSend(topic,str);
        System.out.println("采用点对点模式发送消息"+msg);
    }
}

注意:在启动类添加开启定时任务 

@EnableScheduling

 

消费者

依赖依然是上面的那些

配置文件把端口号改了,8080生产者用了

消费者类

package com.vhukze.consumer;

import com.alibaba.fastjson.JSONObject;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.jms.annotation.JmsListener;
import org.springframework.mail.SimpleMailMessage;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;

@Component
public class P2pConsumer {

    //使用此注解即可监听指定名称的队列
    @JmsListener(destination = "${my_queue}")
    public void recive(String msg){

        System.out.println("采用点对点模式消费者成功获取到生产者的消息:"+msg);
    }

}

这是点对点模式,发布订阅模式只需要把代码中注释打开,换了Queue的即可

然后在配置文件中添加开启发布订阅模式

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章