spring整合activemq点对点消息模式

maven 引用(spring的引用不再贴出)

       <dependency>
		    <groupId>org.apache.activemq</groupId>
		    <artifactId>activemq-pool</artifactId>
		    <version>5.9.0</version>
		</dependency>
		<dependency>
		    <groupId>org.apache.activemq</groupId>
		    <artifactId>activemq-all</artifactId>
		    <version>5.9.0</version>
		</dependency>
		
		<dependency>  
            <groupId>org.springframework</groupId>  
            <artifactId>spring-jms</artifactId>  
            <version>4.3.3.RELEASE</version>  
        </dependency> 

Producer的spring-jms.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" 
	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-4.3.xsd">
	<description>JMS配置</description>

	<!-- ActiveMQ 连接工厂 -->
	<bean id="jmsFactory" class="org.apache.activemq.pool.PooledConnectionFactory"
		destroy-method="stop">
		<property name="connectionFactory">
			<bean class="org.apache.activemq.ActiveMQConnectionFactory">
				<property name="brokerURL" value="${jms.broker_url}" /> 
				<property name="userName" value="${jms.userName}" />
				<property name="password" value="${jms.password}" />
			</bean>
		</property>
		<property name="maxConnections" value="100"></property>
	</bean>

	<!-- Spring Caching 连接工厂 -->
	<bean id="cachingConnectionFactory"
		class="org.springframework.jms.connection.CachingConnectionFactory">
		<property name="targetConnectionFactory" ref="jmsFactory" />
		<property name="sessionCacheSize" value="10" />
	</bean>

	<!-- Spring JMS Template -->
	<bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
		<property name="connectionFactory" ref="cachingConnectionFactory" />
	</bean>

	<bean id="activeApplyQueue" class="org.apache.activemq.command.ActiveMQQueue">
		<constructor-arg value="welkin.activeApply" />
	</bean>
	
	<bean class="org.springframework.jms.config.DefaultJmsListenerContainerFactory" id="jmsListenerContainerFactory">
        <property name="connectionFactory" ref="cachingConnectionFactory" />
    </bean>
	<jms:annotation-driven />
</beans>

Producer代码

package com.cloud.interfaces.active.mq.produce;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.stereotype.Component;

import java.io.Serializable;

import javax.jms.Destination;
@Component("activeMessageProducer")
public class ActiveMessageProducer {

    @Autowired(required = false)
    private JmsTemplate jmsTemplate;

    @Autowired(required = false)
    @Qualifier("activeApplyQueue")
    private Destination notifyQueue;

    public void send(final Serializable ob) {
        sendMessage(ob, notifyQueue);
    }

    /**
     * 使用jmsTemplate最简便的封装convertAndSend()发送Map类型的消息.
     */
    private void sendMessage(Serializable msg, Destination destination) {
        jmsTemplate.convertAndSend(destination, msg);
    }

    public void setJmsTemplate(JmsTemplate jmsTemplate) {
        this.jmsTemplate = jmsTemplate;
    }

    public void setNotifyQueue(Destination notifyQueue) {
        this.notifyQueue = notifyQueue;
    }

}

消息消费这listener配置文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
	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-4.3.xsd">
	<description>JMS配置</description>

	<!-- ActiveMQ 连接工厂 -->
	<bean id="jmsFactory" class="org.apache.activemq.pool.PooledConnectionFactory"
		destroy-method="stop">
		<property name="connectionFactory">
			<bean class="org.apache.activemq.ActiveMQConnectionFactory">
				<property name="brokerURL" value="${jms.broker_url}" />
				<property name="userName" value="${jms.userName}" />
				<property name="password" value="${jms.password}" />
			</bean>
		</property>
		<property name="maxConnections" value="100"></property>
	</bean>

	<!-- Spring Caching 连接工厂 -->
	<bean id="cachingConnectionFactory"
		class="org.springframework.jms.connection.CachingConnectionFactory">
		<property name="targetConnectionFactory" ref="jmsFactory" />
		<property name="sessionCacheSize" value="10" />
	</bean>

	<!-- Spring JMS Template -->
	<bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
		<property name="connectionFactory" ref="cachingConnectionFactory" />
	</bean>

	<bean id="activeApplyQueue" class="org.apache.activemq.command.ActiveMQQueue">
		<constructor-arg value="welkin.activeApply" />
	</bean>

	<bean id="activeApplyQueueContainer"
		class="org.springframework.jms.listener.DefaultMessageListenerContainer">
		<property name="connectionFactory" ref="cachingConnectionFactory" />
		<property name="destination" ref="activeApplyQueue" />
		<property name="messageListener" ref="activeTransMqListener" />
		<property name="concurrentConsumers" value="3" />
	</bean>
	
	
	<bean class="org.springframework.jms.config.DefaultJmsListenerContainerFactory" id="jmsListenerContainerFactory">
        <property name="connectionFactory" ref="cachingConnectionFactory" />
    </bean>
	<jms:annotation-driven />
</beans>

消费者代码

package com.cloud.welkin.listener;

import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.ObjectMessage;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;


@Component("activeTransMqListener")
public class ActiveTransMqListener implements MessageListener{
private Logger logger = LoggerFactory.getLogger(ActiveTransMqListener.class);
	
	
	/**
	 * MessageListener回调函数.
	 */
	@Override
	public void onMessage(Message message) {
		logger.info("====================ActiveTransMqListener==consume===start====================================");
		
		ObjectMessage m = (ObjectMessage) message;
		//写出自己的逻辑处理
		
		
	}

}

猜你喜欢

转载自my.oschina.net/mingziyaoxiangliang/blog/1799834
今日推荐