JMS学习(二)

明白了一些基本的概念后;现在我们来做一个小的实例:

首先:去官网下载一个ActiveMQ,然后安装到 自己电脑上,然后启动。

在对应的Queue的地方新建一个:TestQueue

ConnectionFactory---->Connection--->Session--->Message
  Destination + Session------------------------------------>Producer
  Destination + Session------------------------------------>MessageConsumer

首先需要得到ConnectionFactoy和Destination,这里创建一个一对一的Queue作为Destination。
  ConnectionFactory factory = new ActiveMQConnectionFactory("vm://localhost");
  Queue queue = new ActiveMQQueue("testQueue");

然后又ConnectionFactory创建一个Connection, 再启动这个Connection:
  Connection connection = factory.createConnection();
  connection.start();

接下来需要由Connection创建一个Session:
  Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE)

下面就可以创建Message了,这里创建一个TextMessage。
  Message message = session.createTextMessage("Hello JMS!");

要想把刚才创建的消息发送出去,需要由Session和Destination创建一个消息生产者:
  MessageProducer producer = session.createProducer(queue);

下面就可以发送刚才创建的消息了:
  producer.send(message);

消息发送完成之后,我们需要创建一个消息消费者来接收这个消息:
  MessageConsumer comsumer = session.createConsumer(queue);
  Message recvMessage = comsumer.receive();

消息消费者接收到这个消息之后,就可以得到它的内容:
System.out.println(((TextMessage)recvMessage).getText());


package com.allen.jms01;
import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageProducer;
import javax.jms.Queue;
import javax.jms.Session;
import javax.jms.TextMessage;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
import org.apache.activemq.command.ActiveMQQueue;
public class MessageSendAndReceive {
 private static final String PRIVATE_QUEUE = "TestQueue";
 private static final String LOCAL_ADDRESS = "tcp://localhost:61616";
 
 public static void main(String[] args) throws JMSException{
 
  ConnectionFactory factory =new ActiveMQConnectionFactory(
                ActiveMQConnection.DEFAULT_USER,
                ActiveMQConnection.DEFAULT_PASSWORD,
                LOCAL_ADDRESS);
  Connection connection = factory.createConnection();
        connection.start();  
       
        Queue queue = new ActiveMQQueue(PRIVATE_QUEUE);
       
        final Session session = connection.createSession(Boolean.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);  
        Message recvMessage = comsumer.receive();  
        System.out.println(((TextMessage)recvMessage).getText());  
 }
}

消息的消费者接收消息可以采用两种方式:

  1、consumer.receive() 或 consumer.receive(int timeout);
  2、注册一个MessageListener。

采用第一种方式,消息的接收者会一直等待下去,直到有消息到达,或者超时。后一种方式会注册一个监听器,当有消息到达的时候,会回调它的onMessage()方法
*******************************************************************
使用注册监听事件,来接受消息

*******************************************************************
 MessageConsumer comsumer = session.createConsumer(queue);  
        /*Message recvMessage = comsumer.receive();  
        System.out.println(((TextMessage)recvMessage).getText());  */
        comsumer.setMessageListener(new MessageListener() {
   @Override
   public void onMessage(Message m) {
    // TODO Auto-generated method stub
     TextMessage textMsg = (TextMessage) m;  
                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、付费专栏及课程。

余额充值