JMS学习笔记

JMS消息传递模式有点对点(P2P)模式和发布/订阅(Publisher/Subscriber)模式。点对点模式使用队列,发布/订阅模式使用Topic。
一、P2P模式的消息发送
QueueConnectionFactory qConnectionFactory 
=(QueueConnectionFactory)ctx.lookup("jmsfactory");
QueueConnection qConnection 
= qConnectionFactory.createQueueConnection();
//QueueConnection.createQueueConnection的第一个参数表示是否使用事务,如果是true,则要调用QueueSession.commit()进行提交,调用QueueSession.rollback()进行回滚。
QueueSession qSession = qConnection.createQueueSession(false,javax.jms.QueueSession.AUTO_ACKNOWLEDGE);
Queue q 
= (Queue)ctx.lookup("jmsqueue");
QueueSender qSender 
= qSession.createSender(q);
Message textMsg 
= qSession.createTextMessage();
qSender.send(textMsg);

二、P2P模式的消息接收
1、同步
使用QueueReceiver.receive()
使用QueueReceiver.receiverNoWait()
代码示例:
= (Queue)ctx.lookup("jmsqueue");
qReceiver 
= qSession.createReceiver(q);
qConnection.start();
textMsg 
= (TextMessage)qReceiver.receiveNoWait();
while(textMsg!=null){
    System.out.println(
"Receiving message " + textMsg.getText());
   textMsg 
= (TextMessage)qReceiver.receiveNoWait(); 
}

qConnection.stop();
2、异步
编写Message Listener(实现javax.jms.MessageListener接口的类),当消息到来时,系统将自动调用Message Listener对象的onMessage()方法
调用QueueReceiver.setMessageListener(Message Listener对象)进行注册。
代码示例:
public class AsyncQueueReceiver implements MessageListener{
    
public void onMessage(Message message){
        
if(message instanceof TextMessage){
            
try{
                TextMessage textMsg 
= message;
                
//对消息进行处理
                String msg = textMsg.getText();
                System.out.println(
"Received message:" + msg);
            }

        }

    }

}


三、发布
/订阅模式的消息发送
代码示例:
TopicConnectionFactory tConnectionFactory 
=(TopicConnectionFactory)ctx.lookup("jmsfactory");
TopicConnection tConnection 
= tConnectionFactory.createTopicConnection();
TopicSession tSession 
= tConnection.createTopicSession(false,javax.jms.TopicSession.AUTO_ACKNOWLEDGE);
Topic t 
= (Topic)ctx.lookup("jmstopic");
TopicPublisher tPublisher 
= tSession.createPublisher(t);
Message textMsg 
= tSession.createTextMessage();
//TODO:为textMsg设置消息内容
//发布消息
tPublisher.publish(textMsg);

二、发布
/订阅模式的消息接收
1、同步接收代码示例:
TopicSubscriber tSubscriber 
= tSession.createSubscriber(t);
tConnection.start();
textMsg 
= (TextMessage)tSubscriber.receive();
while(true){
    msg 
= textMsg.getText();
    System.out.println(
"Receiving message: " + msg);
    ...
}

2、异步接收代码示例:
代码示例:
public class AsyncTopicSubscriber implements MessageListener{
    
public void onMessage(Message message){
        
if(message instanceof TextMessage){
            
try{
                TextMessage textMsg 
= message;
                
//对消息进行处理
                String msg = textMsg.getText();
                System.out.println(
"Received message:" + msg);
            }

        }

    }

}
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值