ActiveMQ 使用笔记

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);
    }
}

转载于:https://my.oschina.net/nk2011/blog/366395

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值