ActiveMQ与Spring整合

1、jar包依赖

因为ActiveMQ5.12后的jar包自带spring,不方便与spring整合,可以使用ActiveMQ5.11.2的jar包

  (ActiveMQ默认的端口号为:8161)

<!-- spring对于jms支持的jar包 -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jms</artifactId>
        </dependency>
        <!-- activemq -->
        <dependency>
            <groupId>org.apache.activemq</groupId>
            <artifactId>activemq-all</artifactId>
        </dependency>

2、Spring配置文件

2.1、queue:点对点主题(连接ActiveMQ默认的端口号为:61616)

    在该主题下,会自动将生产者每次提供的信息持久化,当出现多个消费者时,只有第一个消费者能获取生产者的信息

    生产者的配置如下:

<!-- jsm服务厂商提供的连接工厂 -->
    <bean id="targetConnectionFactroy" class="org.apache.activemq.ActiveMQConnectionFactory">
        <property name="brokerURL" value="tcp://192.168.25.132:61616"></property>
    </bean>
    
    <!-- spring用于管理真正的ConnectionFactory -->
    <bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory">
        <property name="targetConnectionFactory" ref="targetConnectionFactroy"></property>
    </bean>
    
    <!-- spring提供的工具类 -->
    <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
        <constructor-arg name="connectionFactory" ref="connectionFactory"></constructor-arg>
    </bean>
    
    <!-- queue -->
    <bean id="queueTextDestination" class="org.apache.activemq.command.ActiveMQQueue">
        <constructor-arg name="name" value="queue_text"></constructor-arg>     //自定义生产者名字
    </bean>

  生产者demo:

@Component
public class QueueProducer {
    @Autowired
    private JmsTemplate jmsTemplate;
    
    @Autowired
    private Destination queueTextDestination;
    
    /**
     * 发送消息
     */
    public void sendTextMessage(final String text){
        jmsTemplate.send(queueTextDestination, new MessageCreator() {
            
            @Override
            public Message createMessage(Session session) throws JMSException {
                
                return session.createTextMessage(text);
            }
        });
    }
}

  queue主题下消费者的配置:

<!-- 监听类(用来监听到mq中是否有消息) -->
    <bean id="myMessageListener" class="com.jd.demo.MyMessageListener"></bean>
    <!-- 消息的监听器 -->
    <bean class="org.springframework.jms.listener.DefaultMessageListenerContainer">
        <property name="connectionFactory" ref="connectionFactory" />
        <property name="destination" ref="queueTextDestination" />
        <property name="messageListener" ref="myMessageListener" />
    </bean>

  2.1、topic:订阅式主题(连接ActiveMQ默认的端口号为:61616)

      在该主题下,生产者的消息不会被持久化,如果没有消费者接收,则消息就会丢失;如果有多个消费者在等待接收消息,生产者的消息会同时被所有消费者接收。

      生产者的配置如下:

<!-- jsm服务厂商提供的连接工厂 -->
    <bean id="targetConnectionFactroy" class="org.apache.activemq.ActiveMQConnectionFactory">
        <property name="brokerURL" value="tcp://192.168.25.132:61616"></property>
    </bean>
    
    <!-- spring用于管理真正的ConnectionFactory -->
    <bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory">
        <property name="targetConnectionFactory" ref="targetConnectionFactroy"></property>
    </bean>
    
    <!-- spring提供的工具类 -->
    <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
        <constructor-arg name="connectionFactory" ref="connectionFactory"></constructor-arg>
    </bean>
    
    <!-- topic -->
    <bean id="topicTextDestination" class="org.apache.activemq.command.ActiveMQTopic">
        <constructor-arg name="name" value="topic_text"></constructor-arg>
    </bean>

  生产者demo:

@Component
public class TopicProducer {
    @Autowired
    private JmsTemplate jmsTemplate;
    
    @Autowired
    private Destination topicTextDestination;
    
    //发送消息
    public void sendTextMessage(final String text){
        jmsTemplate.send(topicTextDestination, new MessageCreator() {
            
            @Override
            public Message createMessage(Session session) throws JMSException {
                
                return session.createTextMessage(text);
            }
        });
    }

}

  消费者配置如下:

<!-- 监听类(用来监听到mq中是否有消息) -->
    <bean id="myMessageListener" class="com.jd.demo.MyMessageListener"></bean>
    <!-- 消息的监听器 -->
    <bean class="org.springframework.jms.listener.DefaultMessageListenerContainer">
        <property name="connectionFactory" ref="connectionFactory" />
        <property name="destination" ref="topicTextDestination" />
        <property name="messageListener" ref="myMessageListener" />
    </bean>

3、消费者demo

public class MyMessageListener implements MessageListener{

    @Override
    public void onMessage(Message message) {
        TextMessage textMessage = (TextMessage) message;
        try {
            System.out.println("接收到的消息是:" + textMessage.getText());
        } catch (JMSException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

}