Spring ActiveMQ

消息生产者代码

@Service
public class ProducerServiceImpl implements ProducerService {

private static Logger _log = LoggerFactory.getLogger(ConsumerServiceImpl.class);

@Resource(name="producerDao") 
private ProducerDao producerDao;


/**
* 向默认队列发送消息
*/
public void sendQueueMessage(String msg) {
_log.info("向队列发送了消息------------" + msg);
producerDao.sendQueueMessage(msg);
}
/**
* 向topic发送消息
*/
@Override
public void sendTopicMessage(String topicName, String message) {
producerDao.sendTopicMessage(topicName, message);

}

}


@Service
public class ConsumerServiceImpl implements ConsumerService {

private static Logger _log = LoggerFactory.getLogger(ConsumerServiceImpl.class);

@Resource(name="consumerDao")
private ConsumerDao consumerDao;


/**
* 接受消息
*/
public void receiveQueueMessage(Destination destination) {
_log.debug("接受消息");
consumerDao.receiveQueueMessage(destination);
}


}




/** 
 * Description: <br/> 
 * 消息队列监听器 
 * @author hetiewei 
 * @date 2016年4月25日 上午10:32:14 
 * 
 */  
public class QueueReceiver1 implements MessageListener { 

private static Logger _log = LoggerFactory.getLogger(ConsumerDaoImpl.class);

    public void onMessage(Message message) { 
        try { 
        _log.info("\n\n~~~~~~~~~~~~~~~~~~~~~~~~消息队列监听器1~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n");  
        _log.info("QueueReceiver1接收到消息:"+((TextMessage)message).getText());  
        _log.info("\n\n~~~~~~~~~~~~~~~~~~~~~~~~消息队列监听器1~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n");  
        }catch (JMSException e) { 
            e.printStackTrace();  
        } 
    } 
      

}


public class TopicReceiver2 implements MessageListener{ 


private static Logger _log = LoggerFactory.getLogger(ConsumerDaoImpl.class);

    public void onMessage(Message message) { 
        try { 
        _log.info("\n\n~~~~~~~~~~~~~~~~~~~~~~~~消息主题监听器2~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n"); 
        _log.info("TopicReceiver2接收到消息:"+((TextMessage)message).getText());  
        _log.info("\n\n~~~~~~~~~~~~~~~~~~~~~~~~消息主题监听器2~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n"); 
        }catch (JMSException e) { 
            e.printStackTrace();  
        } 
    } 
  

}


public class ConsumerDaoImpl implements ConsumerDao {

private static Logger _log = LoggerFactory.getLogger(ConsumerDaoImpl.class);

@Autowired
@Qualifier("jmsQueueTemplate") 
private JmsTemplate jmsQueueTemplate;

@Autowired
@Qualifier("jmsTopicTemplate") 
private JmsTemplate jmsTopicTemplate;


/**
* 接受消息
*/
public void receiveQueueMessage(Destination destination) {
TextMessage tm = (TextMessage) jmsQueueTemplate.receive(destination);
try {
_log.info("从队列" + destination.toString() + "收到了消息:\t" + tm.getText());
}catch (JMSException e) {
e.printStackTrace();
}
}


}


/**
 * 消息生产者代码
 * 
 * @author zhanxz
 * 
 */
public class ProducerDaoImpl implements ProducerDao {

private static Logger _log = LoggerFactory.getLogger(ConsumerDaoImpl.class);

@Autowired
@Qualifier("jmsQueueTemplate") 
private JmsTemplate jmsQueueTemplate;


@Autowired
@Qualifier("jmsTopicTemplate") 
private JmsTemplate jmsTopicTemplate;

@Resource(name="demoQueueDestination")
    private Destination testQueue;

/**
* 向指定队列发送消息
*/
public void sendQueueMessage(final String msg) {
_log.info("向队列" + testQueue.toString() + "发送了消息------------" + msg);
jmsQueueTemplate.send(testQueue, new MessageCreator() {
public Message createMessage(Session session) throws JMSException {
return session.createTextMessage(msg);
}
});
}


@Override
public void sendTopicMessage(String topicName, final String message) {
_log.info("向topic" + topicName + "发送了消息------------" + message);
jmsTopicTemplate.send(topicName, new MessageCreator() { 
            public Message createMessage(Session session) throws JMSException { 
                return session.createTextMessage(message);  
            } 
        });  
}

}

 <!-- ActiveMQ 连接工厂 -->
    <!-- 真正可以产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供-->
    <!-- 如果连接网络:tcp://ip:61616;未连接网络:tcp://localhost:61616 以及用户名,密码-->
    <amq:connectionFactory id="amqConnectionFactory"  
        brokerURL="tcp://localhost:61616" userName="admin" password="admin"  />  
  
    <!-- Spring Caching连接工厂 -->
    <!-- Spring用于管理真正的ConnectionFactory的ConnectionFactory -->  
    <bean id="connectionFactory" class="org.springframework.jms.connection.CachingConnectionFactory">  
        <!-- 目标ConnectionFactory对应真实的可以产生JMS Connection的ConnectionFactory -->  
        <property name="targetConnectionFactory" ref="amqConnectionFactory"></property>  
        <!-- 同上,同理 -->
        <!-- <constructor-arg ref="amqConnectionFactory" /> -->
        <!-- Session缓存数量 -->
        <property name="sessionCacheSize" value="100" />  
    </bean>  
  
    <!-- Spring JmsTemplate 的消息生产者 start-->
  <!-- 配置JMS模板(Queue),Spring提供的JMS工具类,它发送、接收消息。 -->
    <!-- 定义JmsTemplate的Queue类型 -->
    <bean id="jmsQueueTemplate" class="org.springframework.jms.core.JmsTemplate">  
        <!-- 这个connectionFactory对应的是我们定义的Spring提供的那个ConnectionFactory对象 -->  
        <constructor-arg ref="connectionFactory" />  
        <!-- 非pub/sub模型(发布/订阅),即队列模式 -->
        <!-- true是topic,false是queue,默认是false,此处显示写出false -->
        <property name="pubSubDomain" value="false" />  
    </bean>  
  
    <!-- 定义JmsTemplate的Topic类型 -->
    <bean id="jmsTopicTemplate" class="org.springframework.jms.core.JmsTemplate">  
         <!-- 这个connectionFactory对应的是我们定义的Spring提供的那个ConnectionFactory对象 -->  
        <constructor-arg ref="connectionFactory" />  
        <!-- pub/sub模型(发布/订阅) --> 
        <!-- true是topic,false是queue,默认是false,此处显示写出false --> 
        <property name="pubSubDomain" value="true" />  
    </bean>  
  
    <!--Spring JmsTemplate 的消息生产者 end-->
  <!-- 定义消息队列(Queue) -->
    <bean id="demoQueueDestination" class="org.apache.activemq.command.ActiveMQQueue">
        <!-- 设置消息队列的名字 -->
        <constructor-arg>
            <value>test.queue</value>
        </constructor-arg>
    </bean>
    <!-- 定义消息主题(Topic) -->
    <bean id="demoTopicDestination" class="org.apache.activemq.command.ActiveMQTopic">
        <!-- 设置消息队列的名字 -->
        <constructor-arg>
            <value>test.topic</value>
        </constructor-arg>
    </bean>
  
    <!-- 消息消费者 start-->
  
    <!-- 定义Queue监听器 -->
    <jms:listener-container destination-type="queue" container-type="default" connection-factory="connectionFactory" acknowledge="auto">  
        <jms:listener destination="test.queue" ref="queueReceiver1"/>  
        <jms:listener destination="test.queue" ref="queueReceiver2"/>  
    </jms:listener-container>  
  
    <!-- 定义Topic监听器 -->
    <jms:listener-container destination-type="topic" container-type="default" connection-factory="connectionFactory" acknowledge="auto">  
        <jms:listener destination="test.topic" ref="topicReceiver1"/>  
        <jms:listener destination="test.topic" ref="topicReceiver2"/>  
    </jms:listener-container>  
  
    <!-- 消息消费者 end -->
    <bean id="queueReceiver1" class="zxz.framework.activemq.listener.QueueReceiver1" />
    <bean id="queueReceiver2" class="zxz.framework.activemq.listener.QueueReceiver2" />
    <bean id="topicReceiver1" class="zxz.framework.activemq.listener.TopicReceiver1" />
    <bean id="topicReceiver2" class="zxz.framework.activemq.listener.TopicReceiver2" />
    <!-- 注册监听器 -->
    
    <!-- 实现类注册 -->
    <bean id="consumerDao" class="zxz.framework.activemq.impl.ConsumerDaoImpl" />
    <bean id="producerDao" class="zxz.framework.activemq.impl.ProducerDaoImpl" />


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值