深入浅出 消息队列 ActiveMQ

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。

一、 概述与介绍

ActiveMQ 是Apache出品,最流行的、功能强大的即时通讯和集成模式的开源服务器。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现。提供客户端支持跨语言和协议,带有易于在充分支持JMS 1.1和1.4使用J2EE企业集成模式和许多先进的功能。

二、 特性

1、 多种语言和协议编写客户端。语言: Java、C、C++、C#、Ruby、Perl、Python、PHP。应用协议:OpenWire、Stomp REST、WS Notification、XMPP、AMQP

2、完全支持JMS1.1和J2EE 1.4规范 (持久化,XA消息,事务)

3、对Spring的支持,ActiveMQ可以很容易内嵌到使用Spring的系统里面去,而且也支持Spring2.0的特性

4、通过了常见J2EE服务器(如 Geronimo、JBoss 4、GlassFish、WebLogic)的测试,其中通过JCA 1.5 resource adaptors的配置,可以让ActiveMQ可以自动的部署到任何兼容J2EE 1.4 商业服务器上

5、支持多种传送协议:in-VM、TCP、SSL、NIO、UDP、JGroups、JXTA

6、支持通过JDBC和journal提供高速的消息持久化

7、从设计上保证了高性能的集群,客户端-服务器,点对点

8、支持Ajax

9、支持与Axis的整合

10、可以很容易得调用内嵌JMS provider,进行测试

三、 安装

开发环境:

System:Windows

JDK:1.6+

IDE:eclipse

apache ActiveMQ 5.8

Email:hoojo_@126.com

Blog:http://blog.csdn.net/IBM_hoojo

http://hoojo.cnblogs.com/

1、 下载ActiveMQ,下载地址:http://www.apache.org/dyn/closer.cgi?path=/activemq/apache-activemq/5.8.0/apache-activemq-5.8.0-bin.zip

2、 解压apache-activemq-5.8.0.zip即可完成ActiveMQ的安装

3、 解压后目录结构如下

image

+bin (windows下面的bat和unix/linux下面的sh) 启动ActiveMQ的启动服务就在这里

+conf (activeMQ配置目录,包含最基本的activeMQ配置文件)

+data (默认是空的)

+docs (index,replease版本里面没有文档)

+example (几个例子)

+lib (activeMQ使用到的lib)

+webapps (系统管理员控制台代码)

+webapps-demo(系统示例代码)

-activemq-all-5.8.0.jar (ActiveMQ的binary)

-user-guide.html (部署指引)

-LICENSE.txt

-NOTICE.txt

-README.txt

其他文件就不相信介绍了,搞Java的应该都知道干什么用的。

你可以进入bin目录,使用activemq.bat双击启动(windows用户可以选择系统位数,如果你是linux的话,就用命令行的发送去启动),如果一切顺利,你就会看见类似下面的信息:

image

如果你看到这个,那么恭喜你成功了。如果你启动看到了异常信息:


Caused by: java.io.IOException: Failed to bind to server socket: tcp://0.0.0.0:61616?maximumConnections=1000&wireformat.maxFrameSize=104857600 due to: java.net.SocketException: Unrecognized Windows Sockets error: 0: JVM_Bind

那么我告诉你,很不幸,你的端口被占用了。接下来你大概想知道是哪个程序占用了你的端口,并kill掉该进程或服务。或者你要尝试修改ActiveMQ的默认端口61616(ActiveMQ使用的默认端口是61616),在大多数情况下,占用61616端口的是Internet Connection Sharing (ICS) 这个Windows服务,你只需停止它就可以启动ActiveMQ了。

4、 启动成功就可以访问管理员界面:http://localhost:8161/admin,默认用户名和密码admin/admin。如果你想修改用户名和密码的话,在conf/jetty-realm.properties中修改即可。

image

其中在导航菜单中,Queues是队列方式消息。Topics是主题方式消息。Subscribers消息订阅监控查询。Connections可以查看链接数,分别可以查看xmpp、ssl、stomp、openwire、ws和网络链接。Network是网络链接数监控。Send可以发送消息数据。

5、 运行demo示例,在dos控制台输入activemq.bat xbean:../conf/activemq-demo.xml 即可启动demo示例。官方提供的user-guide.html中的access the web console中是提示输入:activemq.bat console xbean:conf/activemq-demo.xml,我用这种方式不成功。

当然你还可以用绝对的文件目录方式:activemq.bat xbean:file:D:/mq/conf/activemq-demo.xml

image

如果提示conf/activemq-demo.xml没有找到,你可以尝试改变下路径,也就是去掉上面的“..”。通过http://localhost:8161/demo/ 就可以访问示例了。

image

四、 消息示例

1、ActiviteMQ消息有3中形式

 

JMS 公共

点对点域

发布/订阅域

ConnectionFactory

QueueConnectionFactory

TopicConnectionFactory

Connection

QueueConnection

TopicConnection

Destination

Queue

Topic

Session

QueueSession

TopicSession

MessageProducer

QueueSender

TopicPublisher

MessageConsumer

QueueReceiver

TopicSubscriber

(1)、点对点方式(point-to-point)

点对点的消息发送方式主要建立在 Message Queue,Sender,reciever上,Message Queue 存贮消息,Sneder 发送消息,receive接收消息.具体点就是Sender Client发送Message Queue ,而 receiver Cliernt从Queue中接收消息和"发送消息已接受"到Quere,确认消息接收。消息发送客户端与接收客户端没有时间上的依赖,发送客户端可以在任何时刻发送信息到Queue,而不需要知道接收客户端是不是在运行

(2)、发布/订阅 方式(publish/subscriber Messaging)

发布/订阅方式用于多接收客户端的方式.作为发布订阅的方式,可能存在多个接收客户端,并且接收端客户端与发送客户端存在时间上的依赖。一个接收端只能接收他创建以后发送客户端发送的信息。作为subscriber ,在接收消息时有两种方法,destination的receive方法,和实现message listener 接口的onMessage 方法。

2、ActiviteMQ接收和发送消息基本流程

image

发送消息的基本步骤:

(1)、创建连接使用的工厂类JMS ConnectionFactory

(2)、使用管理对象JMS ConnectionFactory建立连接Connection,并启动

(3)、使用连接Connection 建立会话Session

(4)、使用会话Session和管理对象Destination创建消息生产者MessageSender

(5)、使用消息生产者MessageSender发送消息

 

消息接收者从JMS接受消息的步骤

(1)、创建连接使用的工厂类JMS ConnectionFactory

(2)、使用管理对象JMS ConnectionFactory建立连接Connection,并启动

(3)、使用连接Connection 建立会话Session

(4)、使用会话Session和管理对象Destination创建消息接收者MessageReceiver

(5)、使用消息接收者MessageReceiver接受消息,需要用setMessageListener将MessageListener接口绑定到MessageReceiver消息接收者必须实现了MessageListener接口,需要定义onMessage事件方法。

五、 代码示例

在代码开始,我们先建一个project,在这个project中添加如下jar包

image

添加完jar包后就可以开始实际的代码工作了。

1、 使用JMS方式发送接收消息消息发送者package com.hoo.mq.jms;import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.DeliveryMode;
import javax.jms.Destination;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;/*** <b>function:</b> 消息发送者* @author hoojo* @createDate 2013-6-19 上午11:26:43* @file MessageSender.java* @package com.hoo.mq.jms* @project ActiveMQ-5.8* @blog http://blog.csdn.net/IBM_hoojo* @email hoojo_@126.com* @version 1.0*/
public class MessageSender {// 发送次数public static final int SEND_NUM = 5;// tcp 地址public static final String BROKER_URL = "tcp://localhost:61616";// 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsppublic static final String DESTINATION = "hoo.mq.queue";/*** <b>function:</b> 发送消息* @author hoojo* @createDate 2013-6-19 下午12:05:42* @param session* @param producer* @throws Exception*/    public static void sendMessage(Session session, MessageProducer producer) throws Exception {for (int i = 0; i < SEND_NUM; i++) {String message = "发送消息第" + (i + 1) + "条";TextMessage text = session.createTextMessage(message);System.out.println(message);producer.send(text);}}public static void run() throws Exception {Connection connection = null;Session session = null;try {// 创建链接工厂ConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, BROKER_URL);// 通过工厂创建一个连接connection = factory.createConnection();// 启动连接connection.start();// 创建一个session会话session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);// 创建一个消息队列Destination destination = session.createQueue(DESTINATION);// 创建消息制作者MessageProducer producer = session.createProducer(destination);// 设置持久化模式producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);sendMessage(session, producer);// 提交会话session.commit();} catch (Exception e) {throw e;} finally {// 关闭释放资源if (session != null) {session.close();}if (connection != null) {connection.close();}}}public static void main(String[] args) throws Exception {MessageSender.run();}
}接受者package com.hoo.mq.jms;import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.Session;
import javax.jms.TextMessage;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;/*** <b>function:</b> 消息接收者* @author hoojo* @createDate 2013-6-19 下午01:34:27* @file MessageReceiver.java* @package com.hoo.mq.jms* @project ActiveMQ-5.8* @blog http://blog.csdn.net/IBM_hoojo* @email hoojo_@126.com* @version 1.0*/
public class MessageReceiver {// tcp 地址public static final String BROKER_URL = "tcp://localhost:61616";// 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsppublic static final String DESTINATION = "hoo.mq.queue";public static void run() throws Exception {Connection connection = null;Session session = null;try {// 创建链接工厂ConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, BROKER_URL);// 通过工厂创建一个连接connection = factory.createConnection();// 启动连接connection.start();// 创建一个session会话session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);// 创建一个消息队列Destination destination = session.createQueue(DESTINATION);// 创建消息制作者MessageConsumer consumer = session.createConsumer(destination);while (true) {// 接收数据的时间(等待) 100 msMessage message = consumer.receive(1000 * 100);TextMessage text = (TextMessage) message;if (text != null) {System.out.println("接收:" + text.getText());} else {break;}}// 提交会话session.commit();} catch (Exception e) {throw e;} finally {// 关闭释放资源if (session != null) {session.close();}if (connection != null) {connection.close();}}}public static void main(String[] args) throws Exception {MessageReceiver.run();}
}

 

2、 Queue队列方式发送点对点消息数据发送方package com.hoo.mq.queue;import javax.jms.DeliveryMode;
import javax.jms.MapMessage;
import javax.jms.Queue;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSession;
import javax.jms.Session;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;/*** <b>function:</b> Queue 方式消息发送者* @author hoojo* @createDate 2013-6-19 下午04:34:36* @file QueueSender.java* @package com.hoo.mq.queue* @project ActiveMQ-5.8* @blog http://blog.csdn.net/IBM_hoojo* @email hoojo_@126.com* @version 1.0*/
public class QueueSender {// 发送次数public static final int SEND_NUM = 5;// tcp 地址public static final String BROKER_URL = "tcp://localhost:61616";// 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsppublic static final String DESTINATION = "hoo.mq.queue";/*** <b>function:</b> 发送消息* @author hoojo* @createDate 2013-6-19 下午12:05:42* @param session* @param sender* @throws Exception*/    public static void sendMessage(QueueSession session, javax.jms.QueueSender sender) throws Exception {for (int i = 0; i < SEND_NUM; i++) {String message = "发送消息第" + (i + 1) + "条";MapMessage map = session.createMapMessage();map.setString("text", message);map.setLong("time", System.currentTimeMillis());System.out.println(map);sender.send(map);}}public static void run() throws Exception {QueueConnection connection = null;QueueSession session = null;try {// 创建链接工厂QueueConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, BROKER_URL);// 通过工厂创建一个连接connection = factory.createQueueConnection();// 启动连接connection.start();// 创建一个session会话session = connection.createQueueSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);// 创建一个消息队列Queue queue = session.createQueue(DESTINATION);// 创建消息发送者javax.jms.QueueSender sender = session.createSender(queue);// 设置持久化模式sender.setDeliveryMode(DeliveryMode.NON_PERSISTENT);sendMessage(session, sender);// 提交会话session.commit();} catch (Exception e) {throw e;} finally {// 关闭释放资源if (session != null) {session.close();}if (connection != null) {connection.close();}}}public static void main(String[] args) throws Exception {QueueSender.run();}
}接收方package com.hoo.mq.queue;import javax.jms.JMSException;
import javax.jms.MapMessage;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.Queue;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSession;
import javax.jms.Session;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;/*** <b>function:</b> 消息接收者; 依赖hawtbuf-1.9.jar* @author hoojo* @createDate 2013-6-19 下午01:34:27* @file MessageReceiver.java* @package com.hoo.mq.queue* @project ActiveMQ-5.8* @blog http://blog.csdn.net/IBM_hoojo* @email hoojo_@126.com* @version 1.0*/
public class QueueReceiver {// tcp 地址public static final String BROKER_URL = "tcp://localhost:61616";// 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsppublic static final String TARGET = "hoo.mq.queue";public static void run() throws Exception {QueueConnection connection = null;QueueSession session = null;try {// 创建链接工厂QueueConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, BROKER_URL);// 通过工厂创建一个连接connection = factory.createQueueConnection();// 启动连接connection.start();// 创建一个session会话session = connection.createQueueSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);// 创建一个消息队列Queue queue = session.createQueue(TARGET);// 创建消息制作者javax.jms.QueueReceiver receiver = session.createReceiver(queue);receiver.setMessageListener(new MessageListener() { public void onMessage(Message msg) { if (msg != null) {MapMessage map = (MapMessage) msg;try {System.out.println(map.getLong("time") + "接收#" + map.getString("text"));} catch (JMSException e) {e.printStackTrace();}}} }); // 休眠100ms再关闭Thread.sleep(1000 * 100); // 提交会话session.commit();} catch (Exception e) {throw e;} finally {// 关闭释放资源if (session != null) {session.close();}if (connection != null) {connection.close();}}}public static void main(String[] args) throws Exception {QueueReceiver.run();}
}
3、 Topic主题发布和订阅消息消息发送方package com.hoo.mq.topic;import javax.jms.DeliveryMode;
import javax.jms.MapMessage;
import javax.jms.Session;
import javax.jms.Topic;
import javax.jms.TopicConnection;
import javax.jms.TopicConnectionFactory;
import javax.jms.TopicPublisher;
import javax.jms.TopicSession;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;/*** <b>function:</b> Queue 方式消息发送者* @author hoojo* @createDate 2013-6-19 下午04:34:36* @file QueueSender.java* @package com.hoo.mq.topic* @project ActiveMQ-5.8* @blog http://blog.csdn.net/IBM_hoojo* @email hoojo_@126.com* @version 1.0*/
public class TopicSender {// 发送次数public static final int SEND_NUM = 5;// tcp 地址public static final String BROKER_URL = "tcp://localhost:61616";// 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsppublic static final String DESTINATION = "hoo.mq.topic";/*** <b>function:</b> 发送消息* @author hoojo* @createDate 2013-6-19 下午12:05:42* @param session 会话* @param publisher 发布者* @throws Exception*/    public static void sendMessage(TopicSession session, TopicPublisher publisher) throws Exception {for (int i = 0; i < SEND_NUM; i++) {String message = "发送消息第" + (i + 1) + "条";MapMessage map = session.createMapMessage();map.setString("text", message);map.setLong("time", System.currentTimeMillis());System.out.println(map);publisher.send(map);}}public static void run() throws Exception {TopicConnection connection = null;TopicSession session = null;try {// 创建链接工厂TopicConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, BROKER_URL);// 通过工厂创建一个连接connection = factory.createTopicConnection();// 启动连接connection.start();// 创建一个session会话session = connection.createTopicSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);// 创建一个消息队列Topic topic = session.createTopic(DESTINATION);// 创建消息发送者TopicPublisher publisher = session.createPublisher(topic);// 设置持久化模式publisher.setDeliveryMode(DeliveryMode.NON_PERSISTENT);sendMessage(session, publisher);// 提交会话session.commit();} catch (Exception e) {throw e;} finally {// 关闭释放资源if (session != null) {session.close();}if (connection != null) {connection.close();}}}public static void main(String[] args) throws Exception {TopicSender.run();}
}接收方package com.hoo.mq.topic;import javax.jms.JMSException;
import javax.jms.MapMessage;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.Session;
import javax.jms.Topic;
import javax.jms.TopicConnection;
import javax.jms.TopicConnectionFactory;
import javax.jms.TopicSession;
import javax.jms.TopicSubscriber;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;/*** <b>function:</b> 消息接收者; 依赖hawtbuf-1.9.jar* @author hoojo* @createDate 2013-6-19 下午01:34:27* @file MessageReceiver.java* @package com.hoo.mq.topic* @project ActiveMQ-5.8* @blog http://blog.csdn.net/IBM_hoojo* @email hoojo_@126.com* @version 1.0*/
public class TopicReceiver {// tcp 地址public static final String BROKER_URL = "tcp://localhost:61616";// 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsppublic static final String TARGET = "hoo.mq.topic";public static void run() throws Exception {TopicConnection connection = null;TopicSession session = null;try {// 创建链接工厂TopicConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, BROKER_URL);// 通过工厂创建一个连接connection = factory.createTopicConnection();// 启动连接connection.start();// 创建一个session会话session = connection.createTopicSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);// 创建一个消息队列Topic topic = session.createTopic(TARGET);// 创建消息制作者TopicSubscriber subscriber = session.createSubscriber(topic);subscriber.setMessageListener(new MessageListener() { public void onMessage(Message msg) { if (msg != null) {MapMessage map = (MapMessage) msg;try {System.out.println(map.getLong("time") + "接收#" + map.getString("text"));} catch (JMSException e) {e.printStackTrace();}}} }); // 休眠100ms再关闭Thread.sleep(1000 * 100); // 提交会话session.commit();} catch (Exception e) {throw e;} finally {// 关闭释放资源if (session != null) {session.close();}if (connection != null) {connection.close();}}}public static void main(String[] args) throws Exception {TopicReceiver.run();}
}

4、 整合Spring实现消息发送和接收,在整合之前我们需要添加jar包,需要的jar包如下

image

这些jar包可以在D:\apache-activemq-5.8.0\lib这个lib目录中找到,添加完jar包后就开始编码工作。

这里的整合就比较简单了,如果你是web工程,那你在需要用jms的时候,只需用注入jmsTemplate即可。

消息发送者
package com.hoo.mq.spring.support;import java.util.Date;
import javax.jms.JMSException;
import javax.jms.MapMessage;
import javax.jms.Message;
import javax.jms.Session;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.jms.core.MessageCreator;/*** <b>function:</b> Spring JMSTemplate 消息发送者* @author hoojo* @createDate 2013-6-24 下午02:18:48* @file Sender.java* @package com.hoo.mq.spring.support* @project ActiveMQ-5.8* @blog http://blog.csdn.net/IBM_hoojo* @email hoojo_@126.com* @version 1.0*/
public class Sender {public static void main(String[] args) {ApplicationContext ctx = new FileSystemXmlApplicationContext("classpath:applicationContext-*.xml");JmsTemplate jmsTemplate = (JmsTemplate) ctx.getBean("jmsTemplate");jmsTemplate.send(new MessageCreator() {public Message createMessage(Session session) throws JMSException {MapMessage message = session.createMapMessage();message.setString("message", "current system time: " + new Date().getTime());return message;}});}
}消息接收者
package com.hoo.mq.spring.support;import java.util.Map;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import org.springframework.jms.core.JmsTemplate;/*** <b>function:</b> Spring JMSTemplate 消息接收者* @author hoojo* @createDate 2013-6-24 下午02:22:32* @file Receiver.java* @package com.hoo.mq.spring.support* @project ActiveMQ-5.8* @blog http://blog.csdn.net/IBM_hoojo* @email hoojo_@126.com* @version 1.0*/
public class Receiver {@SuppressWarnings("unchecked")public static void main(String[] args) {ApplicationContext ctx = new FileSystemXmlApplicationContext("classpath:applicationContext-*.xml");  JmsTemplate jmsTemplate = (JmsTemplate) ctx.getBean("jmsTemplate");  while(true) {  Map<String, Object> map =  (Map<String, Object>) jmsTemplate.receiveAndConvert();  System.out.println("收到消息:" + map.get("message"));  }  }
}这里主要是用到了JmsTemplate这个消息模板,
这个对象在spring的IoC容器中管理,
所以要从spring的容器上下文中获取。
下面看看spring的配置文件applicationContext-beans.xml内容:<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:context="http://www.springframework.org/schema/context"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context-3.1.xsd"><!-- 连接池  --><bean id="pooledConnectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory" destroy-method="stop">  <property name="connectionFactory">  <bean class="org.apache.activemq.ActiveMQConnectionFactory">  <property name="brokerURL" value="tcp://localhost:61616" />  </bean>  </property>  </bean>  <!-- 连接工厂 --><bean id="activeMQConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">  <property name="brokerURL" value="tcp://localhost:61616" />  </bean>  <!-- 配置消息目标 --><bean id="destination" class="org.apache.activemq.command.ActiveMQQueue">  <!-- 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsp --><constructor-arg index="0" value="hoo.mq.queue" />  </bean>  <!-- 消息模板 --><bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">  <property name="connectionFactory" ref="activeMQConnectionFactory" />  <property name="defaultDestination" ref="destination" />  <property name="messageConverter">  <bean class="org.springframework.jms.support.converter.SimpleMessageConverter" /></property>  </bean>  
</beans>

转自:https://blog.csdn.net/jwdstef/article/details/17380471

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/448905.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2018-2019 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2018) - 4.28

赛后补了几道 赛中我就写了两个... A - Altruistic AmphibiansGym - 101933A 看了眼榜没几个人做。就没看。 最后发现就是一个DP&#xff08;但是我觉得复杂度有点迷&#xff09; 题意&#xff1a;$n$只青蛙有参数$l,w,h$分别表示弹跳力&#xff0c;体重&#xff0c;身高&#…

消息队列技术介绍 : ActiveMQ、RabbitMQ、ZeroMQ、Kafka、MetaMQ、RocketMQ

一、 消息队列概述 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 消息队列中间件是分布式系统中重要的组件&#xff0c;主要解决应用耦合、异步消息、流量削锋等问题。实现高性能、高可…

程序员的恶性循环 !

穷人的恶性循环&#xff1a; 穷 -> 需要努力工作 -> 没有时间去交际 -> 人脉越来越狭窄 -> 工作越来越难做 -> 越需要努力去工作 -> 越没有时间去发展人脉 -> 越穷 富人的良性循环&#xff1a; 有钱 -> 工作很轻松 -> 很多时间都在交际上 -> 人…

刷脸考勤,重新定位校园管理

近几年&#xff0c;人脸识别技术在安防领域得到了广泛应用&#xff0c;随着技术的不断发展&#xff0c;它离我们的日常生活越来越近&#xff0c;手机、商场、公园、校园等都可以看到它的身影。刷脸考勤&#xff0c;重新定义校园管理。人脸识别&#xff0c;也叫面部识别&#xf…

python爬虫学习之页面登陆

爬虫学习的一点心得 登陆主要有3种方法&#xff1a;使用selenium&#xff0c;cookies&#xff0c;模拟表单登陆 个人对于一般情况使用cookies登陆 可以实现一次手动&#xff0c;长期自动&#xff0c;可以绕过登陆&#xff08;登陆的相关信息密码&#xff0c;账号等会存于cookie…

消息队列 应用场景 解析

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 另外腾讯云-云社区还有一文不允许转载&#xff0c;但内容挺好的&#xff1a;https://cloud.tencent.com/developer/article/1006035 分布…

求职面试的时候如何谈薪酬待遇

在社会大学里混了那么多年&#xff0c;我最惨痛的经历就是&#xff0c;在应聘一家企业的时候&#xff0c;总是羞于谈薪酬待遇。大概这是很多职场新人都会遇到过的尴尬吧——觉得自己经验不够&#xff0c;或者想应聘的企业比较好&#xff0c;就觉得对方提多少就是多少吧&#xf…

利用memcached实现CAS单点登录集群部署

前言&#xff1a;利用memcached实现CAS单点登录集群部署 负载均衡&#xff1a;将接口请求的有状态性变成无状态性。是我们在实现负载均衡时必要要解决的问题。以应用接口的session状态为例&#xff0c;一般解决方法都是将session数据和应用进行剥离&#xff0c;session数据统一…

注册

<!DOCTYPE html><html lang"en"><head> <meta charset"UTF-8"> <title>注册</title> {# 导入jQuery基础类库&#xff0c;才可以使用 $ #} <script src"../static/js/jquery-1.12.4.min.js"&…

Linux中10个有用的命令行补齐命令

本文由 极客范 - 踏雁寻花 翻译自 Balakrishnan Mariyappan。欢迎加入极客翻译小组&#xff0c;同我们一道翻译与分享。转载请参见文章末尾处的要求。在Linux系统中&#xff0c;输入一个命令&#xff0c;再按两次TAB键&#xff0c;就会列出所有以输入字符开头的可用命令。这并…

分布式开放消息系统 ( RocketMQ ) 的原理与实践

分布式消息系统作为实现分布式系统可扩展、可伸缩性的关键组件&#xff0c;需要具有高吞吐量、高可用等特点。而谈到消息系统的设计&#xff0c;就回避不了两个问题&#xff1a; 消息的顺序问题消息的重复问题RocketMQ作为阿里开源的一款高性能、高吞吐量的消息中间件&#xff…

数据结构02-链表

说明&#xff1a;由于该数据结构是由java并且是原生实现&#xff0c;所以与C有一些出入&#xff0c;不过原理是相同的 1.链表的定义 为了表示线性表元素a与a1的逻辑关系&#xff0c;存储数据时&#xff0c;除了存储元素本身的信息之外&#xff0c;还存储了直接后继元素的位置信…

第四章 面向对象

第四章 面向对象 1. 基本格式 定义&#xff1a;当函数(业务功能)比较多&#xff0c;可以使用面向对象来进行归类&#xff0c;如果有一个凡事使用的公共值&#xff0c;也可以放到对象中 #格式&关键字 class 类名:def __inti__(self,x)self.x xdef 方法名(self,name):print(…

洛谷P2347 砝码称重 某一年noip提高组原题

可以转化为01背包求方案数的问题&#xff0c;dp数组f[][]表示第几个砝码能称出的重量,可压缩至一维 转移方程为f(i,j)f(i-1,j-w[i]) 当前我们可以称出的重量必定是由之前的砝码重量转移过来的 #include<bits/stdc.h> using namespace std; const int N550; const int max…

解决:-bash: unzip: command not found (Linux 中 unZip/Zip 的安装及使用)

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 Linux系统没有自带的压缩解压工具&#xff1b;需要我们自己安装&#xff1b; 当用到zip或者unzip如果没有安装就会出现 unzip: Command…

云计算时代IT专业人员需具备的10项技能

摘要&#xff1a;IT专业人员需要不断的学习&#xff0c;才能确保自己的工作能力跟上时代的步伐。云时代IT专业人员不仅需要具备一定的专业技能&#xff0c;比如快速运用自身知识快速在互联网上构建应用程序&#xff0c;还必须具备商业、金融、业务需求分析等等。 【编者按】谈…

java自定义注解学习笔记

注解学习笔记之自定义注解 Target&#xff08;{1,2,3,4,5,6,7}&#xff09; 1.ElementType.CONSTRUCTOR:用于描述构造器2.ElementType.FIELD:用于描述域3.ElementType.LOCAL_VARIABLE:用于描述局部变量4.ElementType.METHOD:用于描述方法5.ElementType.PACKAGE:用于描述包6.Ele…

[xsy3132]数表

题意&#xff1a;一个$n\times m$的数表&#xff0c;数值$\in[0,4)$&#xff0c;你可以任意次选择一行或一列$1,\text{mod }4$&#xff0c;要最小化所有数的和 因为$n\leq10$&#xff0c;所以数表可以看成$m$个$n$位$4$进制数$a_{1\cdots m}$&#xff0c;以下使用不进位加法 定…

linux 下载、安装 maven

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 1. 创建maven的文件夹并下载maven的tar包到此文件夹中 //进入一个目录 cd /usr/local//创建一个文件夹 mkdir maven//下载maven的tar包…

ELK4之进阶学习

1.精确查找和模糊查找(term和match的区别) match经过分析(analyer)的, term是不经过分词,直接去倒排索引中查找精确的值. 2.建议器的简介(最左前缀或者自带的做) (1)直接用现成的 (2)不只是纠错,还有建议等等. (3)优点:用户体验,服务器减少请求(减少压力,太耗电了,热量太大) (4…