• 带你走进EJB--MDB


        

        在之前的文章中我们介绍了带你走进EJB--JMS 带你走进EJB--JMS编程模型JMS有了初步的了解, 作为EJB系列的文章我们会继续对EJB相关的内容做进一步深的学习和了解.而此次需要进行的是MDB.

            MDB(Message DrivenBean)消息驱动Bean.它是EJBJMS的一个整合,SessionBean 一样,MDB是由EJB容器进行管理,同时也可以利用EJB所提供的系统服务诸如事务,安全等.


            我们可以通过MDB的规范,能够使用更为简洁的方式来开发JMS异步消费者,作为开发者需要的是去实现onMessage方法即可,你不需要去获取JMS链接,不需要JMS Session,也不需要关心MDB启动,因为这些EJB容器会帮你来做,需要做的是通过Annotation来制定JMS消息的目的和类型即可.

            因为MDB是从无状态的Session Bean 发展过来的,所以他们两个有很相似的地方.而在这里我们需要了解他们的不同即可.

     

            无状态Session Bean提供了业务接口,客户端需要通过同步的方式来调用无状态的Session Bean .是一种同步的通讯方式.

            MDB不需要客户端直接调用,它是一个消息监听者.是一种异步的通讯方式.

     


           接下来我们通过一个MDB的例子来具体展示如何使用MDB.因为我们已经知道MDB不需要直接面向客户端,所以它不需要定义任何借口(Session Bean对比,它需要一个定义接口,为客户端服务.),一个Bean类即可,同时因为要做为消息监听器使用,因为要去实现MessageListener接口.

     

     

    
    
    	package com.tgb.ejb;
    	
    	import javax.ejb.ActivationConfigProperty;
    	import javax.ejb.MessageDriven;
    	import javax.jms.JMSException;
    	import javax.jms.Message;
    	import javax.jms.MessageListener;
    	import javax.jms.TextMessage;
    	
    	@MessageDriven(
    		activationConfig = {
    			@ActivationConfigProperty(propertyName="destinationType",propertyValue="javax.jms.Queue"),
    			@ActivationConfigProperty(propertyName="destination",propertyValue="queue/myqueue")
    		}
    	)
    	public class MyQueueMDBBean implements MessageListener {
    	
    		public void onMessage(Message msg) {
    			try {
    				TextMessage textMessage = (TextMessage)msg;
    				System.out.println("MyQueueMDBBean被调用了【"+textMessage.getText()+"】");
    			} catch (JMSException e) {
    				e.printStackTrace();
    			}
    		}
    	
    	}
    


     

     

            上面的MDB在收到JMS消息之后只是简单的或许了JMS消息中的信息,它并没有调用SessionBean来处理所接受到的信息.

          将此MDB编译并部署到JBoss应用服务器中,它就可以监听JDNI为queue/myqueue的消息目的.

     

          接下来我们需要开发一个应用程序来向JBoss服务器的消息目的发送消息.客户端如下:

           

     

    package com.tgb.ejb;
    
    import javax.jms.JMSException;
    import javax.jms.Queue;
    import javax.jms.QueueConnection;
    import javax.jms.QueueConnectionFactory;
    import javax.jms.QueueSender;
    import javax.jms.QueueSession;
    import javax.jms.TextMessage;
    import javax.naming.InitialContext;
    import javax.naming.NamingException;
    
    public class MyQueueBeanClient {
    
    	/**建立Queue 客户端
    	 * @param args
    	 * @throws NamingException 
    	 * @throws JMSException 
    	 */
    	public static void main(String[] args) throws NamingException, JMSException {
    		InitialContext context = new InitialContext();
    		//创建QueueConnectionFactory
    		QueueConnectionFactory factory=(QueueConnectionFactory)context.lookup("ConnectionFactory");
    		
    		//创建QueueConnection
    		QueueConnection queueConnection= factory.createQueueConnection();
    		
    		//创建QueueSession
    		QueueSession queueSession =queueConnection.createQueueSession(false, QueueSession.AUTO_ACKNOWLEDGE);
    		
    		
    		//获取Destination对象
    		Queue queue = (Queue)context.lookup("queue/myqueue");
    		//创建文本对象
    		TextMessage textMessage = queueSession.createTextMessage("hello world!");
    		
    		//创建发送者
    		QueueSender sender = queueSession.createSender(queue);
    		
    		//发送消息
    		sender.send(textMessage);
    		
    		//关闭资源
    		queueSession.close();
    		queueConnection.close();
    		
    		System.out.println("消息已发送");
    		
    	}
    
    }
    

     

     

    运行客户端我们就向JMS 的消息目的地发送一个简单的文本消息.随后MDB会被出发,以下是效果

    计算机生成了可选文字:16:47:26,767INFO[sTDouT]MyQueueMDBBean被调用7[heiioworid!]

            

           小结:通过上面的实例我们能够看到,虽然客户端不能直接与EJB交互,但是依然能够跟它进行通讯,这是一种低耦合的方式通讯.虽然本实例获取消息之后仅仅简单的在控制台上打印消息,但在实际的项目中MDB会获取JMS消息中的信息之后需要调用Session Bean对信息进行处理,例如在用户注册信息之后通知用户并发送相关的邮件信息.这个业务可以通过MDB来完成,只需要通过依赖注入将Session Bean注入此MDB中即可.

            在进行的过程中还会出现一个NameNotFoundException的问题,在下一篇文章中对此进行解决.

        

  • 相关阅读:
    Django框架之第三篇模板语法
    Django框架之第二篇
    Django框架第一篇基础
    【数学基础】【快速幂运算模板】
    【搜索】【广搜模板】
    【动态规划】【子序列模板】
    [置顶] 【ACM模板】——hello_chengdongni 随着姿势提升,不定期补充
    【搜索入门专题1】 hdu1242 J
    【搜索入门专题1】E
    【搜索入门专题1】hdu1253 【BFS】 F
  • 原文地址:https://www.cnblogs.com/pangblog/p/3295333.html
Copyright © 2020-2023  润新知