安装ActiveMQ

使用brew安装https://blog.csdn.net/u010046908/article/details/54728375

直接下载安装https://blog.csdn.net/ytangdigl/article/details/77740100

启动

  1. activemq start

帐号密码都是admin

默认端口8161

搭建项目框架

这边拿一个简易的spring+springMVC为框架

添加pom依赖

  1. <!--activity工作流依赖-->
  2. <dependency>
  3. <groupId>org.activiti</groupId>
  4. <artifactId>activiti-engine</artifactId>
  5. <version>${activiti.version}</version>
  6. </dependency>
  7. <!-- activiti 与 Spring 集成 -->
  8. <dependency>
  9. <groupId>org.activiti</groupId>
  10. <artifactId>activiti-spring</artifactId>
  11. <version>${activiti.version}</version>
  12. </dependency>
  13.  
  14. <!--activeMq依赖包-->
  15. <dependency>
  16. <groupId>org.apache.activemq</groupId>
  17. <artifactId>activemq-all</artifactId>
  18. <version>5.13.2</version>
  19. </dependency>
  20. <!--spring和mq的依赖包-->
  21. <!-- https://mvnrepository.com/artifact/org.springframework/spring-jms -->
  22. <dependency>
  23. <groupId>org.springframework</groupId>
  24. <artifactId>spring-jms</artifactId>
  25. <version>4.3.8.RELEASE</version>
  26. </dependency>
  27.  
  28. <dependency>
  29. <groupId>org.springframework</groupId>
  30. <artifactId>spring-messaging</artifactId>
  31. <version>4.3.8.RELEASE</version>
  32. </dependency>

添加spring-config.xml中的schema

  1. xmlns:amq="http://activemq.apache.org/schema/core"
  2. xmlns:jms="http://www.springframework.org/schema/jms"
  3.  
  4. http://activemq.apache.org/schema/core http://activemq.apache.org/schema/core/activemq-core-5.8.0.xsd
  5. http://www.springframework.org/schema/jms http://www.springframework.org/schema/jms/spring-jms-4.0.xsd

  

添加配置

  1.   <!--mq配置-->
  2. <!--mq的消息中心,brokerURL中心的位置-->
  3. <amq:connectionFactory brokerURL="tcp://localhost:61616" userName="admin" password="admin"
  4. id="amqconnectionFactory"/>
  5.  
  6. <!--spring和jms的连接targetConnectionFactory是写死的-->
  7. <bean id="connectionFactory" class="org.springframework.jms.connection.CachingConnectionFactory">
  8. <property name="targetConnectionFactory" ref="amqconnectionFactory"/>
  9. <!--缓存大小-->
  10. <property name="sessionCacheSize" value="10"/>
  11. </bean>
  12.  
  13. <!--配置两种模式-->
  14. <!--点对点模式-->
  15. <!--发布订阅-->
  16. <!--id为jmsTemplate,可能id会重复-->
  17. <bean id="queueTemplate" class="org.springframework.jms.core.JmsTemplate">
  18. <constructor-arg ref="connectionFactory"/>
  19. <!--不接收 pubSubDomain:是不是队列-->
  20. <property name="pubSubDomain" value="false"/>
  21. <!--消息不会持久化了-->
  22. <!--<property name="deliveryMode" value="1"/>-->
  23. </bean>
  24.  
  25. <!--订阅者-->
  26. <bean id="topicTemplate" class="org.springframework.jms.core.JmsTemplate">
  27. <constructor-arg ref="connectionFactory"/>
  28. <!--接收-->
  29. <property name="pubSubDomain" value="true"/>
  30. </bean>
  31.  
  32. <!--监听-->
  33. <!--acknowledge消息课靠性传输,属性auto默认自动确认机制,-->
  34. <!-- prefetch="100" 传输次数,和幂有关系-->
  35. <!--destination-type=urableTopic可以设置持久化和非持久化-->
  36. <!--接收信息queue点对点-->
  37. <jms:listener-container destination-type="queue" connection-factory="connectionFactory">
  38. <!-- destination监听的对列-->
  39. <jms:listener destination="oldboy.queue" ref="queueReceicer_one"/>
  40. <jms:listener destination="oldboy.queue" ref="queueReceicer_two"/>
  41. </jms:listener-container>
  42.  
  43. <!--发送信息queue发布订阅-->
  44. <jms:listener-container destination-type="topic" connection-factory="connectionFactory">
  45. <!--destination监听的对列-->
  46. <jms:listener destination="oldboy.topic" ref="topicReceicer_one"/>
  47. <jms:listener destination="oldboy.topic" ref="topicReceicer_two"/>
  48. </jms:listener-container>

  

创建和配置文件对应的类

P2P模式(点point对点point)

QueueReceicer_one.java

  1. import org.springframework.stereotype.Component;
  2.  
  3. import javax.jms.JMSException;
  4. import javax.jms.Message;
  5. import javax.jms.MessageListener;
  6. import javax.jms.TextMessage;
  7.  
  8. /**
  9. * Created by peng on 18/6/26.
  10. */
  11. @Component("queueReceicer_one")
  12. public class QueueReceicer_one implements MessageListener {
  13.  
  14. @Override
  15. public void onMessage(Message message) {
  16.  
  17. try {
  18. System.out.println("queueReceicer_one:"+((TextMessage) message).getText());
  19. } catch (JMSException e) {
  20. e.printStackTrace();
  21. }
  22. }
  23. }

  

QueueReceicer_two.java

  1. import org.springframework.stereotype.Component;
  2.  
  3. import javax.jms.JMSException;
  4. import javax.jms.Message;
  5. import javax.jms.MessageListener;
  6. import javax.jms.TextMessage;
  7.  
  8. /**
  9. * Created by peng on 18/6/26.
  10. */
  11. @Component("queueReceicer_two")
  12. public class QueueReceicer_two implements MessageListener{
  13.  
  14. @Override
  15. public void onMessage(Message message) {
  16. try {
  17. System.out.println("queueReceicer_two:"+((TextMessage)message).getText());
  18. } catch (JMSException e) {
  19. e.printStackTrace();
  20. }
  21. }
  22. }

  

QueueSender.java

  1. import org.springframework.beans.factory.annotation.Autowired;
  2. import org.springframework.beans.factory.annotation.Qualifier;
  3. import org.springframework.jms.core.JmsTemplate;
  4. import org.springframework.jms.core.MessageCreator;
  5. import org.springframework.stereotype.Component;
  6.  
  7. import javax.jms.JMSException;
  8. import javax.jms.Message;
  9. import javax.jms.Session;
  10.  
  11. /**
  12. * Created by peng on 18/6/26.
  13. */
  14. @Component
  15. public class QueueSender {
  16.  
  17. @Autowired
  18. @Qualifier("queueTemplate")
  19. private JmsTemplate template;
  20.  
  21. public void send(String queueName , final String message){
  22. template.send(queueName, new MessageCreator() {
  23. @Override
  24. public Message createMessage(Session session) throws JMSException {
  25. return session.createTextMessage(message);
  26. }
  27. });
  28. }
  29.  
  30. }

  

发布订阅模式

TopicReceicer_one.java

  1. import org.springframework.stereotype.Component;
  2.  
  3. import javax.jms.JMSException;
  4. import javax.jms.Message;
  5. import javax.jms.MessageListener;
  6. import javax.jms.TextMessage;
  7.  
  8. /**
  9. * Created by peng on 18/6/26.
  10. */
  11. @Component("topicReceicer_one")
  12. public class TopicReceicer_one implements MessageListener {
  13.  
  14. @Override
  15. public void onMessage(Message message) {
  16. try {
  17. System.out.println("topicReceicer_one:"+((TextMessage)message).getText());
  18. } catch (JMSException e) {
  19. e.printStackTrace();
  20. }
  21. }
  22. }

  

TopicReceicer_two.java

  1. import org.springframework.stereotype.Component;
  2.  
  3. import javax.jms.JMSException;
  4. import javax.jms.Message;
  5. import javax.jms.MessageListener;
  6. import javax.jms.TextMessage;
  7.  
  8. /**
  9. * Created by peng on 18/6/26.
  10. */
  11. @Component("topicReceicer_two")
  12. public class TopicReceicer_two implements MessageListener {
  13.  
  14. @Override
  15. public void onMessage(Message message) {
  16. try {
  17. System.out.println("topicReceicer_two:"+((TextMessage)message).getText());
  18. } catch (JMSException e) {
  19. e.printStackTrace();
  20. }
  21. }
  22. }

  

TopicSender.java

  1. import org.springframework.beans.factory.annotation.Autowired;
  2. import org.springframework.beans.factory.annotation.Qualifier;
  3. import org.springframework.jms.core.JmsTemplate;
  4. import org.springframework.jms.core.MessageCreator;
  5. import org.springframework.stereotype.Component;
  6.  
  7. import javax.jms.JMSException;
  8. import javax.jms.Message;
  9. import javax.jms.Session;
  10.  
  11. /**
  12. * Created by peng on 18/6/26.
  13. */
  14. @Component
  15. public class TopicSender {
  16.  
  17. @Autowired
  18. @Qualifier("topicTemplate")
  19. private JmsTemplate template;
  20.  
  21. public void send(String queueName , final String message){
  22. template.send(queueName, new MessageCreator() {
  23. @Override
  24. public Message createMessage(Session session) throws JMSException {
  25. return session.createTextMessage(message);
  26. }
  27. });
  28. }
  29.  
  30. }

  

调用

MqTest.java

  1. import oldboy.vip.controller.service.QueueSender;
  2. import oldboy.vip.controller.service.TopicSender;
  3. import org.springframework.beans.factory.annotation.Autowired;
  4. import org.springframework.stereotype.Controller;
  5. import org.springframework.web.bind.annotation.RequestMapping;
  6. import org.springframework.web.bind.annotation.ResponseBody;
  7.  
  8. /**
  9. * Created by peng on 18/6/26.
  10. */
  11. @Controller
  12. @RequestMapping("mq")
  13. public class MqTest {
  14.  
  15. @Autowired
  16. private QueueSender queueSender;
  17.  
  18. @Autowired
  19. private TopicSender topicSender;
  20.  
  21. @RequestMapping("/test1")
  22. @ResponseBody
  23. public String test1(){
  24. queueSender.send("oldboy.queue","oldboy");//oldboy.queue和配置文件中destination对应
  25. topicSender.send("oldboy.topic","oldboy");//oldboy.topic和配置文件中destination对应
  26.  
  27. return "oldboy.vip";
  28. }
  29.  
  30. }

  

最终目录结构

启动项目

控制台接收到消息

点对点的只能收一个人收到

消息订阅的可以所有人收到

可以在acitveMQ中看到(可以查看12是因为测试的次数比较多。。)

代码已经扔到github上了https://github.com/oldboyooxx/activeMQDemo对你有帮助喜欢点个喜欢~

ActiveMQ消息队列使用和配置的更多相关文章

  1. activemq消息队列的使用及应用docker部署常见问题及注意事项

    activemq消息队列的使用及应用docker部署常见问题及注意事项 docker用https://hub.docker.com/r/rmohr/activemq/配置在/data/docker/a ...

  2. JAVA的设计模式之观察者模式----结合ActiveMQ消息队列说明

    1----------------------观察者模式------------------------------ 观察者模式:定义对象间一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的 ...

  3. ActiveMQ消息队列从入门到实践(4)—使用Spring JMS收发消息

    Java消息服务(Java Message Service ,JMS)是一个Java标准,定义了使用消息代理的通用API .在JMS出现之前,每个消息代理都有私有的API,这就使得不同代理之间的消息代 ...

  4. SpringBoot集成ActiveMq消息队列实现即时和延迟处理

    原文链接:https://blog.csdn.net/My_harbor/article/details/81328727 一.安装ActiveMq 具体安装步骤:自己谷歌去 二.新建springbo ...

  5. ActiveMQ 消息队列服务

      1 ActiveMQ简介 1.1 ActiveMQ是什么 ActiveMQ是一个消息队列应用服务器(推送服务器).支持JMS规范. 1.1.1 JMS概述 全称:Java Message Serv ...

  6. ActiveMQ基础教程(四):.net core集成使用ActiveMQ消息队列

    接上一篇:ActiveMQ基础教程(三):C#连接使用ActiveMQ消息队列 这里继续说下.net core集成使用ActiveMQ.因为代码比较多,所以放到gitee上:https://gitee ...

  7. (四)RabbitMQ消息队列-服务详细配置与日常监控管理

    原文:(四)RabbitMQ消息队列-服务详细配置与日常监控管理 RabbitMQ服务管理 启动服务:rabbitmq-server -detached[ /usr/local/rabbitmq/sb ...

  8. C#实现ActiveMQ消息队列

    本文使用C#实现ActiveMQ消息队列功能. 一.首先需要导入两个包,分别是:Apache.NMS 和 Apache.NMS.ActiveMQ 二.创建Winform程序实现生产者功能. 三.Pro ...

  9. ActiveMQ消息队列的使用及应用

    这里就不说怎么安装了,直接解压出来就行了. 谢绝转载,作者保留所有权力 目录:  一:JMQ的两种消息模式 1.1:点对点的消息模式 1.2:订阅模式 二:点对点的实现代码 2.1:点对点的发送端 2 ...

随机推荐

  1. 判断是否关注了微信公众号 subscribe 0=未关注 1=已关注

    $appid=''; $secret=''; //微信网页授权获取openid $web_url='http://www.xxxx.com/shouquan.php'; if (!isset($_GE ...

  2. 怎么解决tomcat占用8080端口问题图文教程

     怎么解决tomcat占用8080端口问题 相信很多朋友都遇到过这样的问题吧,tomcat死机了,重启eclipse之后,发现 Several ports (8080, 8009) required ...

  3. Android上传 apk格式文件下载

  4. TensorFlow学习笔记(三)MNIST数字识别问题

    一.MNSIT数据处理 MNSIT是一个非常有名的手写体数字识别数据集.包含60000张训练图片,10000张测试图片.每张图片是28X28的数字. TonserFlow提供了一个类来处理 MNSIT ...

  5. PHP程序执行时间过长,超时了怎么办

    解决办法:修改php.ini文件,把最大的执行时间改为0,0表示不限制时间. max_execution_time = 0

  6. Oracle数据库查找持有锁的SQL语句,而不是请求锁的SQL语句(原创)

    Oracle数据库查找持有锁的SQL语句,而不是请求锁的SQL语句 查找活动的事务以及活动事务关联的会话信息 select s.sid 会话ID, s.serial# 会话序列号, s.usernam ...

  7. link cut tree模板(LCT模板)

    update:2017.09.26 #include <bits/stdc++.h> using namespace std; struct Link_Cut_Tree { + ; ], ...

  8. hdu6206 Apple

    地址:http://acm.split.hdu.edu.cn/showproblem.php?pid=6206 题目: Apple Time Limit: 1000/1000 MS (Java/Oth ...

  9. Codeforces Round #425 (Div. 2) B - Petya and Exam

    地址:http://codeforces.com/contest/832/problem/B 题目: B. Petya and Exam time limit per test 2 seconds m ...

  10. 如何高效的遍历HashMap 以及对key 进行排序

    Map<Integer ,Object> map = new HashMap<Integer,Object>(); for(int i = 0; i<=100;i++){ ...