activemq与spring整合,自动消费队列的配置与代码

原创
2015/08/05 09:36
阅读数 3K
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:context="http://www.springframework.org/schema/context"
    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-4.1.xsd
    http://www.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context-4.1.xsd">
    <!-- 连接池  -->
    <bean id="pooledConnectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory" destroy-method="stop"> 
        <property name="connectionFactory"> 
            <bean class="org.apache.activemq.ActiveMQConnectionFactory"> 
                <property name="brokerURL" value="tcp://localhost:61616" /> 
            </bean> 
        </property> 
    </bean> 
    <!-- 连接工厂 -->
    <bean id="activeMQConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory"> 
        <property name="brokerURL" value="tcp://localhost:61616" /> 
    </bean> 
    <!-- 配置消息目标 -->
    <bean id="destination" class="org.apache.activemq.command.ActiveMQQueue"> 
        <constructor-arg index="0" value="com.netease.mobile.device" /> 
    </bean> 
    <!-- 消息模板 -->
    <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate"> 
        <property name="connectionFactory" ref="activeMQConnectionFactory" /> 
        <property name="defaultDestination" ref="destination" /> 
        <property name="messageConverter"> 
            <bean class="org.springframework.jms.support.converter.SimpleMessageConverter" />
        </property> 
    </bean> 
 <!-- 消息监听器 -->  
    <bean id="consumerMessageListener" class="com.netease.mobileMq.task.deviceCacheFlushTask"/>  
    <!-- 可以获取session的MessageListener -->  
   <!--  <bean id="consumerSessionAwareMessageListener" class="com.netease.mobileMq.task.deviceCacheFlushTask">  
        <property name="destination" ref="destination"/>  
    </bean>   -->
    <!-- 消息监听容器 -->  
    <bean id="jmsContainer"   class="org.springframework.jms.listener.DefaultMessageListenerContainer">  
        <property name="connectionFactory" ref="activeMQConnectionFactory" />  
        <property name="destination" ref="destination" />  
        <property name="messageListener" ref="consumerMessageListener" />  
    </bean>  
    <!-- <bean id="sessionAwareListenerContainer"  
        class="org.springframework.jms.listener.DefaultMessageListenerContainer">  
        <property name="connectionFactory" ref="activeMQConnectionFactory" />  
        <property name="destination" ref="destination" />  
        <property name="messageListener" ref="consumerSessionAwareMessageListener" />  
    </bean>   -->
</beans>
package com.netease.mobileMq.task;

import java.util.Date;
import java.util.List;

import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage;

import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jms.core.JmsTemplate;

import com.alibaba.fastjson.JSON;
import com.netease.commonBean.FlushDeviceCacheBean;
import com.netease.device.constant.EquipmentConstants;
import com.netease.device.dao.EquipmentMapper;
import com.netease.device.dao.FingerUserMapper;
import com.netease.device.entity.EquipmentInfo;
import com.netease.device.entity.FingerUserInfo;
import com.netease.mobile.common.RedisUtil;

/**
 * @author 作者 E-mail:ruanjianlxm@sina.com
 * @version 创建时间:2015年8月4日 下午4:44:39
 * 类说明
 */
public class deviceCacheFlushTask implements  
MessageListener{
	private static Logger logger = LoggerFactory.getLogger("equipmentErrorLog");
	@Autowired
	FingerUserMapper fingerUserMapper;
	@Autowired
	EquipmentMapper equipmentMapper;
	@Autowired
	JmsTemplate jmsTemplate;
	public void onMessage(Message  message){
		 TextMessage textMsg = (TextMessage) message;  
		 
		 String receiveMsg =null;
		try {
			receiveMsg = textMsg.getText();
		} catch (JMSException e1) {
			// TODO Auto-generated catch block
			e1.printStackTrace();
			return ;
		}
		System.out.println("receiveMsg:"+receiveMsg);
		if (StringUtils.isBlank(receiveMsg)) {
			logger.error("deviceCacheFlushTask   receiveMsg is null  Time is " + new Date());
			return ;
		}
		else {
			logger.info("deviceCacheFlushTask   receiveMsg " + receiveMsg);//日志中记录每个刷新的数据
			
		}
		
		FlushDeviceCacheBean flushBean = JSON.parseObject(receiveMsg, FlushDeviceCacheBean.class);//将传过来的刷新对象进行格式化。
		String mainssn = flushBean.getMainssn();
		String[] refIds = flushBean.getUserIds();
		
		/*---------------先更新用户缓存----------*/
		if (mainssn != null) {//有主账号就更新主账号信息
		List<FingerUserInfo> fingerUserInfos = null;
		try {
			fingerUserInfos = fingerUserMapper.getAllEqUserInfoByName(mainssn);
		} catch (Exception e) {
			// TODO: handle exception
			logger.error("EquipmentServiceImpl flushCache error", e);
			return ;
		}

		if (fingerUserInfos == null || fingerUserInfos.size() == 0) {// 如果有一个都没有
			RedisUtil.delete(EquipmentConstants.EQUIPMENT_FINGER_USER_PRE
					+ mainssn);
		} else {
			RedisUtil.set(EquipmentConstants.EQUIPMENT_FINGER_USER_PRE
					+ mainssn, JSON.toJSONString(fingerUserInfos));// 新数据直接替换到缓存中
		}
		}
		/*---------------再更新设备缓存----------*/

		List<EquipmentInfo> equipmentInfos = null;
		
		if (refIds!=null&&refIds.length!=0) {//有ID就刷新ID信息
		for (String refId : refIds) {
			try {
				equipmentInfos = equipmentMapper.getAllEquipmentInfoById(refId);
			} catch (Exception e) {
				// TODO: handle exception
				logger.error("EquipmentServiceImpl flushCache error", e);
				return ;
			}
			if (equipmentInfos == null || equipmentInfos.size() == 0) {// 如果有一个没有,说明查询数据出错失败了
				RedisUtil.delete(EquipmentConstants.EQUIPMENT_EQUINFO_PRE + refId);
			} else {
				RedisUtil.set(EquipmentConstants.EQUIPMENT_EQUINFO_PRE + refId,
						JSON.toJSONString(equipmentInfos));// 新数据直接替换到缓存中
			}
		}
		}
	}

}


展开阅读全文
打赏
0
3 收藏
分享
加载中
更多评论
打赏
0 评论
3 收藏
0
分享
返回顶部
顶部