activeMq-3 Spring整合activeMq

 jdbcTemplate相似的是,Spring也提供了JmsTemplate

 生产者使用JmsTemplate生产消息,消费者实现一个监听器用于获取消息

 项目用maven构建,jdk1.8,

 文末提供免费源码下载

  项目工程截图如下

activemq.properties 主要配置连接activemq相关连接参数

spring-activemq.xml 主要用于配置jmsTemplate

spring-context.xml 主要加载bean

我们重点关注spring-activemq.xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

       <!-- activeMQ工厂: ConnectionFactory -->
       <bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
              <property name="brokerURL" value="${activemq.brokerURL}" />
<!--           <property name="userName" value="${activemq.userName}"></property>
              <property name="password" value="${activemq.password}"></property> -->
       </bean>

       <!--
           ActiveMQ为我们提供了一个PooledConnectionFactory,通过往里面注入一个ActiveMQConnectionFactory
           可以用来将Connection、Session和MessageProducer池化,这样可以大大的减少我们的资源消耗,要依赖于 activemq-pool包
        -->
       <bean id="pooledConnectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory">
              <property name="connectionFactory" ref="targetConnectionFactory" />
              <property name="maxConnections" value="${activemq.pool.maxConnections}" />
       </bean>

       <!-- Spring用于管理真正的ConnectionFactory的ConnectionFactory -->
       <bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory">
         
              <property name="targetConnectionFactory" ref="pooledConnectionFactory" />
       </bean>

       <!--目的地-->
       <bean id="msgQueue" class="org.apache.activemq.command.ActiveMQQueue">
              <constructor-arg>
                     <value>${activemq.queueName}</value>
              </constructor-arg>
       </bean>

       <!-- Spring提供的JMS模板类,它可以进行消息发送、接收等 -->
 
       <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
           
              <property name="connectionFactory" ref="connectionFactory"/>
              <property name="pubSubDomain" value="false"></property> <!-- 设置p2p 还是主题订阅模式 默认是false 即p2p模式 -->
              <property name="defaultDestinationName" value="${activemq.queueName}"></property>
       </bean>

       <!-- 配置自定义监听:MessageListener -->
       <bean id="messageListener" class="com.activemq.listener.ConsumerListener"></bean>

       <!-- 将连接工厂、目标对象、自定义监听注入jms模板 -->
       <bean id="sessionAwareListenerContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer">
              <property name="connectionFactory" ref="connectionFactory" />
              <property name="destination" ref="msgQueue" />
              <property name="messageListener" ref="messageListener" />
       </bean>

</beans>

  

上面只是一些常见的配置 jmsTemplate还有很多配置

生产者代码

 @Service
public class Producer {
	@Autowired
	private JmsTemplate jmsTemplate;
	public void sendTextMessage(String text) {
		jmsTemplate.send(new MessageCreator() {
			@Override
			public Message createMessage(Session session) throws JMSException {
				Message mes =  session.createTextMessage(text);
				return mes;
			}
		});
	}
}

消费者代码(异步监听)

public class ConsumerListener implements SessionAwareMessageListener<Message>{
	@Override
	public void onMessage(Message message, Session session) throws JMSException {
	    
		if(message instanceof TextMessage)
		{
			System.out.println("Text "+((TextMessage)message).getText());
		}
		
	}
}

  

 测试代码

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = { "classpath:spring-context.xml" })
public class TestProducer {
	@Autowired
	private Producer producer;
	
	@Test
	public void send() {
		producer.sendTextMessage("activemq-Spring!");
		
	}
}

  

@RunWith  指明采用SpringJunit4进行测试

@ContextConfiguration 配置Spring核心配置文件位置

结果如下 

注意:消息中间件适用于生产者能力强 而消费者能力弱的场景,就是大量写的情况。

源码下载:http://pan.baidu.com/s/1dFpPHw1

原文地址:https://www.cnblogs.com/javabigdata/p/7479894.html