安装ActiveMQ

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

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

启动

activemq start

帐号密码都是admin

默认端口8161

搭建项目框架

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

添加pom依赖

    <!--activity工作流依赖-->
<dependency>
<groupId>org.activiti</groupId>
<artifactId>activiti-engine</artifactId>
<version>${activiti.version}</version>
</dependency>
<!-- activiti 与 Spring 集成 -->
<dependency>
<groupId>org.activiti</groupId>
<artifactId>activiti-spring</artifactId>
<version>${activiti.version}</version>
</dependency> <!--activeMq依赖包-->
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-all</artifactId>
<version>5.13.2</version>
</dependency>
<!--spring和mq的依赖包-->
<!-- https://mvnrepository.com/artifact/org.springframework/spring-jms -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jms</artifactId>
<version>4.3.8.RELEASE</version>
</dependency> <dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-messaging</artifactId>
<version>4.3.8.RELEASE</version>
</dependency>

添加spring-config.xml中的schema

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

  

添加配置

   <!--mq配置-->
<!--mq的消息中心,brokerURL中心的位置-->
<amq:connectionFactory brokerURL="tcp://localhost:61616" userName="admin" password="admin"
id="amqconnectionFactory"/> <!--spring和jms的连接targetConnectionFactory是写死的-->
<bean id="connectionFactory" class="org.springframework.jms.connection.CachingConnectionFactory">
<property name="targetConnectionFactory" ref="amqconnectionFactory"/>
<!--缓存大小-->
<property name="sessionCacheSize" value="10"/>
</bean> <!--配置两种模式-->
<!--点对点模式-->
<!--发布订阅-->
<!--id为jmsTemplate,可能id会重复-->
<bean id="queueTemplate" class="org.springframework.jms.core.JmsTemplate">
<constructor-arg ref="connectionFactory"/>
<!--不接收 pubSubDomain:是不是队列-->
<property name="pubSubDomain" value="false"/>
<!--消息不会持久化了-->
<!--<property name="deliveryMode" value="1"/>-->
</bean> <!--订阅者-->
<bean id="topicTemplate" class="org.springframework.jms.core.JmsTemplate">
<constructor-arg ref="connectionFactory"/>
<!--接收-->
<property name="pubSubDomain" value="true"/>
</bean> <!--监听-->
<!--acknowledge消息课靠性传输,属性auto默认自动确认机制,-->
<!-- prefetch="100" 传输次数,和幂有关系-->
<!--destination-type=urableTopic可以设置持久化和非持久化-->
<!--接收信息queue点对点-->
<jms:listener-container destination-type="queue" connection-factory="connectionFactory">
<!-- destination监听的对列-->
<jms:listener destination="oldboy.queue" ref="queueReceicer_one"/>
<jms:listener destination="oldboy.queue" ref="queueReceicer_two"/>
</jms:listener-container> <!--发送信息queue发布订阅-->
<jms:listener-container destination-type="topic" connection-factory="connectionFactory">
<!--destination监听的对列-->
<jms:listener destination="oldboy.topic" ref="topicReceicer_one"/>
<jms:listener destination="oldboy.topic" ref="topicReceicer_two"/>
</jms:listener-container>

  

创建和配置文件对应的类

P2P模式(点point对点point)

QueueReceicer_one.java

import org.springframework.stereotype.Component;

import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage; /**
* Created by peng on 18/6/26.
*/
@Component("queueReceicer_one")
public class QueueReceicer_one implements MessageListener { @Override
public void onMessage(Message message) { try {
System.out.println("queueReceicer_one:"+((TextMessage) message).getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
}

  

QueueReceicer_two.java

import org.springframework.stereotype.Component;

import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage; /**
* Created by peng on 18/6/26.
*/
@Component("queueReceicer_two")
public class QueueReceicer_two implements MessageListener{ @Override
public void onMessage(Message message) {
try {
System.out.println("queueReceicer_two:"+((TextMessage)message).getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
}

  

QueueSender.java

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.jms.core.MessageCreator;
import org.springframework.stereotype.Component; import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.Session; /**
* Created by peng on 18/6/26.
*/
@Component
public class QueueSender { @Autowired
@Qualifier("queueTemplate")
private JmsTemplate template; public void send(String queueName , final String message){
template.send(queueName, new MessageCreator() {
@Override
public Message createMessage(Session session) throws JMSException {
return session.createTextMessage(message);
}
});
} }

  

发布订阅模式

TopicReceicer_one.java

import org.springframework.stereotype.Component;

import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage; /**
* Created by peng on 18/6/26.
*/
@Component("topicReceicer_one")
public class TopicReceicer_one implements MessageListener { @Override
public void onMessage(Message message) {
try {
System.out.println("topicReceicer_one:"+((TextMessage)message).getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
}

  

TopicReceicer_two.java

import org.springframework.stereotype.Component;

import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage; /**
* Created by peng on 18/6/26.
*/
@Component("topicReceicer_two")
public class TopicReceicer_two implements MessageListener { @Override
public void onMessage(Message message) {
try {
System.out.println("topicReceicer_two:"+((TextMessage)message).getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
}

  

TopicSender.java

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.jms.core.MessageCreator;
import org.springframework.stereotype.Component; import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.Session; /**
* Created by peng on 18/6/26.
*/
@Component
public class TopicSender { @Autowired
@Qualifier("topicTemplate")
private JmsTemplate template; public void send(String queueName , final String message){
template.send(queueName, new MessageCreator() {
@Override
public Message createMessage(Session session) throws JMSException {
return session.createTextMessage(message);
}
});
} }

  

调用

MqTest.java

import oldboy.vip.controller.service.QueueSender;
import oldboy.vip.controller.service.TopicSender;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody; /**
* Created by peng on 18/6/26.
*/
@Controller
@RequestMapping("mq")
public class MqTest { @Autowired
private QueueSender queueSender; @Autowired
private TopicSender topicSender; @RequestMapping("/test1")
@ResponseBody
public String test1(){
queueSender.send("oldboy.queue","oldboy");//oldboy.queue和配置文件中destination对应
topicSender.send("oldboy.topic","oldboy");//oldboy.topic和配置文件中destination对应 return "oldboy.vip";
} }

  

最终目录结构

启动项目

控制台接收到消息

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

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

可以在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. Spring第九弹—使用CGLIIB实现AOP功能与AOP概念解释

    JDK自从1.3版本开始,就引入了动态代理,并且经常被用来动态地创建代理,原理之前我已经讲过.JDK的动态代理用起来非常简单,但它有一个限制,就是使用动态代理的对象必须实现一个或多个接口.如果想代理没 ...

  2. su 与 su - 区别

    su与su -都是用来切换用户的命令,简单说它们之间的区别就是:su -切换的干净彻底,而su 切换用户却拖泥带水. su su username,切换到指定用户,但是当前目录不会变化,环境变量还是上 ...

  3. WebStorm keyboard shortcuts

    ctrl + D 向下复制 下面是Webstorm的一些常用快捷键: shift + enter: 另起一行 ctrl + alt + L: 格式化代码 control + E:  光标跳到行尾 it ...

  4. vue react angular对比

    1.数据绑定 1)vue 把一个普通对象传给Vued的data选项,Vue会遍历此对象的所有属性,并使用Object.defineProperty将这些属性全部转为getter/setter.Obje ...

  5. SQL各种连接——自连接、内连接、外连接、交叉连接的使用

    首先准备了两个表 (Student 和 Course),其中 Student 表中的 C_S_Id 字段为外键列,关联的是 Course 表的 C_Id 主键列. 内连接(inner join):满足 ...

  6. C#如何获取枚举(Enum)变量的值

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Enum ...

  7. 【转】C#操作xml

    XML文件是一种常用的文件格式,例如WinForm里面的app.config以及Web程序中的web.config文件,还有许多重要的场所都有它的身影.Xml是Internet环境中跨平台的,依赖于内 ...

  8. [pixhawk笔记]8-半物理仿真环境

    通过半物理仿真,可以在不试飞的情况下对飞控的软硬件进行部分验证,下面结合文档对半物理仿真环境的搭建和运行进行学习.先跑起来再说. Pixhawk支持多轴和固定翼的仿真,多轴用jMavSim,固定翼用X ...

  9. saltstack实现自动化扩容

    案例:当nginx的并发达到3000,并持续了一段时间时,通过自动化创建一台虚拟机,部署应用最后添加到集群提供服务: zabbix监控(nginx并发量)------->action------ ...

  10. MR案例:基站相关01

    字段解释: product_no:用户手机号: lac_id:用户所在基站: start_time:用户在此基站的开始时间: staytime:用户在此基站的逗留时间. product_no lac_ ...