Spring环境下ActiveMQ的配置与应用(入门篇)

ActiveMQ是一种符合JMS规范的消息中间件,可以让不同系统间进行通信完成某些功能。例如秒杀系统发送消息让库存系统去进行减库存操作,管理系统修改信息后让搜索系统去更新索引等。最常用的消息类型是TextMessage字符串对象。

1、centOS中ActiveMQ的安装
需要JDK环境。解压即可通过bin目录下的activemq start启动。初学时暂时使用默认配置。
2、ActiveMQ和Spring框架的整合
1)使用maven管理项目,加入spring-jms、spring-context-sport、activemq的依赖
2)配置ConectionFactory (生产者和消费者都需要配置)

<!-- 真正产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供,broker为部署在centOS上的activemq中间件地址 -->
<!-- 支持配置消息重发redeliveryPolicy -->
    <bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
        <property name="brokerURL" value="tcp://192.168.25.168:61616" />
    </bean>
    <!-- Spring包装过的符合jms规范的ConnectionFactory -->
    <bean id="connectionFactory"
        class="org.springframework.jms.connection.SingleConnectionFactory">
        <!-- 目标ConnectionFactory对应真实的可以产生JMS Connection的ConnectionFactory -->
        <property name="targetConnectionFactory" ref="targetConnectionFactory" />
    </bean>

3)消息生产者配置
例如配置在内容管理系统的spirng配置文件中。

<!-- 配置生产者 -->
    <!-- Spring提供的JMS工具类,它可以进行消息发送、接收等-->
    <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
        <!-- 这个connectionFactory对应的是我们定义的Spring提供的那个ConnectionFactory对象 -->
        <property name="connectionFactory" ref="connectionFactory" />
    </bean>
    <!--这个是队列目的地,点对点的 -->
    <bean id="queueDestination" class="org.apache.activemq.command.ActiveMQQueue">
        <constructor-arg>
            <value>spring-queue</value>
        </constructor-arg>
    </bean>
    <!--这个是主题目的地,一对多的 -->
    <bean id="topicDestination" class="org.apache.activemq.command.ActiveMQTopic">
        <constructor-arg value="topic" />
    </bean>

4)消息消费者配置
例如配置在搜索系统的spring配置文件中

<!--这个是队列目的地,点对点的 -->
    <bean id="queueDestination" class="org.apache.activemq.command.ActiveMQQueue">
        <constructor-arg>
            <value>spring-queue</value>
        </constructor-arg>
    </bean>
    <!--这个是主题目的地,一对多的 -->
    <bean id="topicDestination" class="org.apache.activemq.command.ActiveMQTopic">
        <constructor-arg value="topic" />
    </bean>
    <!-- 接收消息 -->
    <!-- 配置监听器 -->
    <bean id="myMessageListener" class="XXX.listener.MyMessageListener" />
    <!-- 消息监听容器 -->
    <bean class="org.springframework.jms.listener.DefaultMessageListenerContainer">
        <property name="connectionFactory" ref="connectionFactory" />
        <property name="destination" ref="queueDestination" />
        <property name="messageListener" ref="myMessageListener" />
        <!-- 和broker的消息确认机制 2为手动确认 这条不写默认为1自动确认-->
        <property name="sessionAcknowledgeMode" value="2"/>
    </bean>
    <!-- 如果有多个消息监听器,则配置多个DefaultMessageListenerContainer -->

3、消息提供方发送消息
jmsTemplate已经将connectionFactory、connection、session等一系列创建操作封装完成,

jmsTemplate.send(destination, new MessageCreator() {
//destination是从容器中获取的bean
@Override
public Message createMessage(Session session) throws JMSException {
                TextMessage textMessage = session.createTextMessage("要发送的消息");
                return textMessage;
            }
        });

4、消息消费方处理消息
以异步消费消息为例,实现一个messageListener并配置到spring容器中。
//TODO: 欠一个主动消费消息,同步方式consumer.receive()

public class myMessageListener implements MessageListener {

    @Override
    public void onMessage(Message message) {
        try {
            TextMessage textMessage = null;
            //取消息
            if (message instanceof TextMessage) {
                textMessage = (TextMessage) message;
                String s = textMessage.getText();
            }
            //使用s作为参数,调用service层方法完成某些业务

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}

5、ActiveMQ如何保证消息可达
消费者和broker通讯最终实现消息确认。自动确认时,在onMessage方法正确返回时确认;手动确认时采用message.acknowledge()进行确认。

6、ActiveMQ消息保留问题
消息生产者发布消息到某一个topic时,只有正在监听该topic地址的消息消费者能够接收到消息;如果没有消息消费者在监听,该topic就丢失了。
而queue数据默认会在mq服务器上以文件形式保存,queue上的消息如果暂时没有消息消费者来取,也不会丢失。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值