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