ActiveMQ 使用笔记
ActiveMQ 的使用非常简单,和JDBC一样,有标准的步骤:
1. 创建连接工厂
2. 创建连接
3. 创建会话
4. 创建目的地
5. 创建生产者或消费者
6. 生产或消费消息
7. 关闭生产或消费者、关闭会话、关闭连接
一个生产者例子如下:
class ActiveMQProducer implements Runnable {
public void run() {
try {
// 创建连接工厂
ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616");
// 创建JMS连接实例,并启动连接
Connection connection = connectionFactory.createConnection();
connection.start();
// 创建Session对象,不开启事务
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
// 创建目标,可以是 Queue 或 Topic
Destination destination = session.createQueue("ling.wcaccepted");
// 创建生成者
MessageProducer producer = session.createProducer(destination);
// 设置消息不需持久化。默认消息需要持久化
producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
// 创建文本消息
TextMessage message = session.createTextMessage("Hello World!");
// 发送消息。non-persistent 默认异步发送;persistent 默认同步发送
producer.send(message);
// 关闭会话和连接
producer.close();
session.close();
connection.close();
} catch(Exception e) {
e.printStackTrace();
}
}
}
一个消费者例子如下:
class ActiveMQConsumer implements Runnable {
public void run() {
try {
// 创建连接工厂
ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616");
// 创建JMS连接实例,并启动连接
Connection connection = connectionFactory.createConnection();
connection.start();
// 创建Session对象,不开启事务
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
// 创建目标,可以是 Queue 或 Topic
Destination destination = session.createQueue("ling.wcaccepted");
// 创建消费者
MessageConsumer consumer = session.createConsumer(destination);
// 获取消息
System.out.println(consumer.receive());
// 关闭会话和连接
consumer.close();
session.close();
connection.close();
} catch(Exception e) {
}
}
}
ActiveMQ 的 Session、MessageProducer 和 MessageConsumer 类是非线程安全的,不能在多线程中共享。
结合Spring使用
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:jms="http://www.springframework.org/schema/jms"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/jms
http://www.springframework.org/schema/jms/spring-jms.xsd">
<!-- ActiveMQ 连接池配置 -->
<bean id="activemqPoolFactory" 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</value>
</property>
</bean>
</property>
</bean>
<!-- Spring JMS Template, 默认开启消息持久化 -->
<bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate" c:connectionFactory-ref="activemqPoolFactory"/>
<!-- ActiveMQ 消费者方法配置,下面配置生成2个listener -->
<jms:listener-container connection-factory="activemqPoolFactory">
<jms:listener destination="ling.activity" ref="activemqClient" method="lingActivity"/>
<jms:listener destination="ling.delete" ref="activemqClient" method="lingDelete"/>
</jms:listener-container>
<!-- ActiveMQ 消费者工具类配置 -->
<bean id="activemqClient" class="com.winhong.ling.utils.ActivemqClient"/>
</beans>
ActiveMQ 消费者工具类代码:
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.Session;
import com.alibaba.fastjson.JSON;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.jms.core.MessageCreator;
/**
* 消息队列工具类。
*
* @author ningjh
* @version 1.0
* @since 2015/1/4
*/
public class ActivemqClient {
public final static String QUEUE_ACTIVITY = "ling.activity";
public final static String QUEUE_DELETE = "ling.delete";
@Autowired
private JmsTemplate jmsTemplate;
/**
* 发送文本消息
*
* @param destination 队列名称
* @param message 文本消息内容
*/
public void sendMessage(String destination, final String message) {
jmsTemplate.send(destination, new MessageCreator() {
public Message createMessage(Session session) throws JMSException {
return session.createTextMessage(message);
}
});
}
/**
* 消费者监听器方法。监听队列 ling.activity
*
* @param message
*/
public void lingActivity(String message) {
System.out.println("接收到消息-activity: " + message);
}
/**
* 消费者监听器方法。监听队列 ling.delete
*
* @param message
*/
public void lingDelete(String message) {
System.out.println("接收到消息-delete: " + message);
}
}