JMS消息队列入门

参考:http://blog.csdn.net/wl_ldy/article/category/1216997

基本概念

JMS(Java Message Service)即java消息服务。它提供了标准的生产、发送和接收信息的借口,简化了企业开发的流程。它提供了两种方式的消息通信模型:点对点的模型、发布/点阅模型。

重要的几个概念:

  • Destination:消息发送的目的地
  • Message:被发送的消息,它包括数据流、map和普通text等类型。
  • Session:信息生成者与消息服务JMS建立的会话,只能通过session创建Message。
  • Connection:信息生产者与消息服务JMS建立的连接,通过它创建Session。
  • ConnectionFactory:连接工厂。
  • Producer:消息生产者。
  • MessageConsumer:消息的消费者。

下面是一个基于ActiveMQ消息服务器的例子

/** 
 * @author Administrator 
 * @desctiption 结合一个例子,深入理解JMS的基本概念 
 * 消息的消费者接收消息可以采用两种方式: 
 * 1、consumer.receive() 或 consumer.receive(int timeout); 
 * 2、注册一个MessageListener。 
 * 采用第一种方式,消息的接收者会一直等待下去,直到有消息到达,或者超时。 
 * 后一种方式会注册一个监听器,当有消息到达的时候,会回调它的onMessage()方法。 
 */  
package com.wl.jms;  

import javax.jms.Connection;  
import javax.jms.ConnectionFactory;  
import javax.jms.JMSException;  
import javax.jms.Message;  
import javax.jms.MessageConsumer;  
import javax.jms.MessageListener;  
import javax.jms.MessageProducer;  
import javax.jms.Queue;  
import javax.jms.Session;  
import javax.jms.TextMessage;  

import org.apache.activemq.ActiveMQConnectionFactory;  
import org.apache.activemq.command.ActiveMQQueue;  

public class MessageSendAndReceive {  

    /** 
     * @param args 
     * @throws JMSException  
     */  
    public static void main(String[] args) throws JMSException {  
        // TODO Auto-generated method stub  
        ConnectionFactory factory = new ActiveMQConnectionFactory("vm://localhost");    

        Connection connection = factory.createConnection();    
        connection.start();    
        //创建消息的Destination   
        Queue queue = new ActiveMQQueue("testQueue");    

        final Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);   
        //创建将要发送的消息  
        Message message = session.createTextMessage("Hello JMS!");    
        //创建消息生产者发送消息   
        MessageProducer producer = session.createProducer(queue);    
        producer.send(message);    

        System.out.println("Send Message Completed!");    
        //创建消息的接收者   
        MessageConsumer comsumer = session.createConsumer(queue);   
        //消息的消费者接收消息的第一种方式:consumer.receive() 或 consumer.receive(int timeout);  
        //Message recvMessage = comsumer.receive();    
        //System.out.println(((TextMessage)recvMessage).getText());   
        //消息的消费者接收消息的第二种方式:注册一个MessageListener  
        comsumer.setMessageListener(new MessageListener(){  
            public void onMessage(Message msg) {  
                // TODO Auto-generated method stub  
                TextMessage textMsg=(TextMessage)msg;  
                try {  
                    System.out.println(textMsg.getText());  
                } catch (JMSException e) {  
                    e.printStackTrace();  
                }  
            }  

        });  
    }  

}  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值