`
十井_
  • 浏览: 56433 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JMS和Message driven bean【转】

阅读更多
这边对初学者理解JMS和MDB比较有帮助。

JMS(Java Message Service)即消息服务。是由sun公司提出,定义java程序访问企业消息传递系统的接口,是J2EE平台上实现面向消息的中间件的规范。面向消息的中间件系统是一种异步通讯系统。非java平台的面向消息的中间件系统也有很多,比较常见的有IBM的MQSeries,Microsoft的MSMQ。
Message driven bean是EJB2.0规范新增加的一种bean,这样就使EJB框架具备了异步消息通讯机制。Message driven bean在JMS系统中扮演消息的消费者(consumer),也就是消息的监听者,而一个客户端着扮演消息的生产者(productor)即消息的发送者。当一个客户端向一个队列或主题发送一个消息后,EJB容器将调用相应的Message driven bean,对收到的消息进行处理,对bean的调用是自动进行的,所要做的只是把消息发送到队列或主题即可。
在此不多说JMS和Message driven bean的详细情况,详细知识请到sun的java网站上取得,或在网上搜索。在这里说明一个简单例子的实现过程。本例子用到的工具软件application server:weblogic 6.1,jdk:jdk1.3。
要想运行一个Message driven bean,先要在weblogic控制台做一些设定。
1.Connection factory的设定
打开weblogic控制台,在左边的Form中选择mydomain/Service//JMS/Connection factory,在右边将会显示Connection factory的配置画面,然后在该画面中选择new JMS Connection Factory configuration。
名字:TestConnFactory
JNDI名:jmstest.JMSConnFactory
其他选项取默认值,点击做成按钮。
  2.JMS的服务器设置
    (1)在左边的Form中选择mydomain/Service//JMS/server,在右边将显示的配置画面,点击new JMSServer configuration。


名字:MyJMSServer
点击作成按钮即作成了server。
(2)然后在左边的form中就可以看到MyJMSServer这一项,下面有destination子项,点击打开,看到destination的设定画面。点击new JMSQueue configuration或者new JMSTopic configuration,这次我们选new JMSTopic configuration。

名字:MyJMSTopic
JNDI名:jmstest.JMSTopic
点击作成按钮。

到此,JMS的服务器端就配置好了。
    先说一下用JMS API做的一个例子。在JMS系统中,消息传递模型分两种,点对点模型(point-to-point model,PTP)和发布/订阅模型(publish and subscribe,pub/sub)。关于这两种模型的详细资料,请在网上查询。下面的例子用的是发布/订阅模型,对于点对点模型处理几乎一模一样,只是用到的有些方法名称不一样。
1. 消息发布程序
package jmstest;

/**
* Title:
* Description:
* Copyright:    Copyright (c) 2001
* Company:
* @author
* @version 1.0
*/

import java.io.*;
import javax.jms.*;
import javax.naming.*;

public class TPublisher {

    public static void main(String[] args) {

        new TPublisher().publish();
    }

    public void publish() {

        BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));

        try {
            //Prompt for JNDI names
            System.out.println("Enter TopicConnectionFactory name:");
            String factoryName = reader.readLine();
            System.out.println("Enter Topic name:");
            String topicName = reader.readLine();

            //Look up administered objects
            Context initContext = Util.getInitialContext();
            TopicConnectionFactory factory =
                (TopicConnectionFactory) initContext.lookup(factoryName);
            Topic topic = (Topic) initContext.lookup(topicName);
            initContext.close();

            //Create JMS objects
            TopicConnection connection = factory.createTopicConnection();
            TopicSession session =
                connection.createTopicSession(false, Session.AUTO_ACKNOWLEDGE);
            TopicPublisher publisher = session.createPublisher(topic);
            // set persistant
            publisher.setDeliveryMode(DeliveryMode.PERSISTENT);

            //Send messages
            String messageText = null;
            while (true) {
                System.out.println("Enter message to send or 'quit':");
                messageText = reader.readLine();
                if ("quit".equals(messageText))
                    break;
                TextMessage message = session.createTextMessage(messageText);
                publisher.publish(message);
            }
            System.out.println("Exiting...");
            reader.close();
            connection.close();
            System.out.println("Goodbye!");

        } catch (Exception e) {
            e.printStackTrace();
            System.exit(1);
        }
    }
}

2.消息订阅程序
package jmstest;

/**
* Title:
* Description:
* Copyright:    Copyright (c) 2001
* Company:
* @author
* @version 1.0
*/

import java.io.*;
import javax.jms.*;
import javax.naming.*;

public class TSubscriber implements MessageListener {

    private boolean stop = false;

    public static void main(String[] args) {

        new TSubscriber().subscribe();
    }

    public void subscribe() {

        BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));

        try {
            //Prompt for JNDI names
            System.out.println("Enter TopicConnectionFactory name:");
            String factoryName = reader.readLine();
            System.out.println("Enter Topic name:");
            String topicName = reader.readLine();
            reader.close();

            //Look up administered objects
            Context initContext = Util.getInitialContext();
            TopicConnectionFactory factory =
                (TopicConnectionFactory) initContext.lookup(factoryName);
            Topic topic = (Topic) initContext.lookup(topicName);
            initContext.close();

            //Create JMS objects
            TopicConnection connection = factory.createTopicConnection();
            TopicSession session =
                connection.createTopicSession(false, Session.AUTO_ACKNOWLEDGE);
            TopicSubscriber subscriber = session.createSubscriber(topic);
            subscriber.setMessageListener(this);
            connection.start();

            //Wait for stop
            while (!stop) {
                Thread.sleep(1000);
            }
            System.out.println("Exiting...");
            connection.close();
            System.out.println("Goodbye!");

        } catch (Exception e) {
            e.printStackTrace();
            System.exit(1);
        }
    }

    public void onMessage(Message message) {

        try {
            String msgText = ((TextMessage) message).getText();
            System.out.println(msgText);
            if ("stop".equals(msgText))
                stop = true;
        } catch (JMSException e) {
            e.printStackTrace();
            stop = true;
        }
    }
}
打开消息订阅程序和消息发布程序,输入我们在上面配置好的connection factory名和topic名,即可通过消息发布程序发送字符消息,在消息订阅程序程序中可以接收到。

    下面再说一下message driven bean的例子。message driven bean在JMS系统中扮演的是消息消费者的角色,即一个message driven bean相当于我们上面例子中的Tsubscriber,只不过它不需要手工调用,由服务器自动调用,也就是说我们只要向某个主题发送消息就可以了,消息将由服务器调用相应的message driven bean去处理。

1.MsgDrvTest.java

package msgdrvbeantest;

/**
* Title:
* Description:
* Copyright:    Copyright (c) 2001
* Company:
* @author
* @version 1.0
*/

import weblogic.rmi.RemoteException;

import javax.ejb.CreateException;
import javax.ejb.MessageDrivenBean;
import javax.ejb.MessageDrivenContext;

import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage;

import javax.naming.InitialContext;
import javax.naming.NamingException;

public class MsgDrvTest implements MessageDrivenBean, MessageListener{
    private MessageDrivenContext m_context;
    private static final boolean VERBOSE = true;

    public MsgDrvTest() {
    }

    private void log(String s) {
        if (VERBOSE) System.out.println(s);
    }

    public void ejbActivate() {
        log("ejbActivate called");
    }

    public void ejbRemove() {
        log("ejbRemove called");
    }

    public void ejbPassivate() {
        log("ejbPassivate called");
    }

    public void setMessageDrivenContext(MessageDrivenContext ctx) {
        log("setMessageDrivenContext called");
        m_context = ctx;
    }

    public void ejbCreate () throws CreateException {
        log("ejbCreate called");
    }

    /////
    // MessageListener complement,we should do something at here
    //

    public void onMessage(Message msg) {
        TextMessage tm = (TextMessage) msg;
        try {
            String text = tm.getText();
            log("Received new message : " + text);
        }
        catch(JMSException ex) {
            ex.printStackTrace();
        }
    }

    //
    // MessageListener complement
    /////
}

2. ejb-jar.xml

<!DOCTYPE ejb-jar PUBLIC "-//Sun Microsystems, Inc.//DTD Enterprise JavaBeans 2.0//EN" "http://java.sun.com/dtd/ejb-jar_2_0.dtd">

<ejb-jar>
<enterprise-beans>
    <message-driven>
      <ejb-name>TestMsgDrvBean</ejb-name>
      <ejb-class>msgdrvbeantest.MsgDrvTest</ejb-class>
      <transaction-type>Container</transaction-type>
      <message-driven-destination>
      <!-- destination type: javax.jms.Topic or javax.jms.Queue -->
        <destination-type>javax.jms.Topic</destination-type>
      </message-driven-destination>
    </message-driven>
</enterprise-beans>
</ejb-jar>

3.weblogic-ejb-jar.xml

<?xml version="1.0"?>
<!DOCTYPE weblogic-ejb-jar PUBLIC "-//BEA Systems, Inc.//DTD WebLogic 6.0.0 EJB//EN" "http://www.bea.com/servers/wls600/dtd/weblogic-ejb-jar.dtd">

<weblogic-ejb-jar>
  <weblogic-enterprise-bean>
    <ejb-name>TestMsgDrvBean</ejb-name>
    <message-driven-descriptor>
      <pool>
        <max-beans-in-free-pool>20</max-beans-in-free-pool>
        <initial-beans-in-free-pool>1</initial-beans-in-free-pool>
      </pool>
      <!-- destination-jndi-name is that we configured at JMS server -->
      <destination-jndi-name>jmstest.JMSTopic</destination-jndi-name>
    </message-driven-descriptor>
    <jndi-name>TestMsgDrvBean</jndi-name>
  </weblogic-enterprise-bean>
</weblogic-ejb-jar>
编译MsgDrvTest.java文件,然后用ejbc,生成jar文件,然后将其发布到weblogic中即可。
测试程序可以用上面的例子中的Tpublisher,输入我们在上面配置好的connection factory名和topic名,然后就可以输入字符消息,比如输入一个单词hello,那么在weblogic的控制台就应该可以看到“Received new message : hello”
分享到:
评论

相关推荐

    EJB3.0开发Message Driven Bean

    @MessageDriven(activationConfig={ @ActivationConfigProperty(propertyName="destinationType", propertyValue="javax.jms.Queue"), @ActivationConfigProperty(propertyName="destination", propertyValue=...

    EJB3.0开发Message Driven Bean.rar

    你需要在类上添加这个注解,并指定消息驱动接口,例如`@MessageDriven(name = "MyMDB", activationConfig = { @ActivationConfigProperty(propertyName = "destinationType", propertyValue = "javax.jms.Queue") })...

    Message-Driven Bean EJB实例源代码

    - 使用`@MessageDriven`注解标记该类,指定JMS目的地类型(队列或主题),以及其他配置属性。 - 在ejb-jar.xml或元数据注解中配置MDB,如JNDI名称、消息驱动适配器等。 6. **源代码解析**: 压缩包中的源代码...

    java源码:Message-Driven Bean EJB实例源代码.zip

    在EJB项目中,我们需要在ejb-jar.xml或@MessageDriven注解中配置MDB的相关属性,如消息监听接口、JMS目的地类型(队列或主题)、JNDI名称等。 **4. MDB的源码分析** 在提供的源码中,我们可能会看到以下关键组件: ...

    基于Java的实例源码-Message-Driven Bean EJB实例源代码.zip

    2. **编写MDB类**:MDB类需要实现`javax.ejb.MessageDrivenBean`接口或者继承`javax.jms.MessageListener`接口,并标注`@MessageDriven`注解。这个注解包含了JMS目的地的配置信息,如目的地类型、激活配置等。 3. *...

    基于java的Message-Driven Bean EJB实例源代码.zip

    - 使用`@MessageDriven`注解来声明bean是一个MDB,并指定JMS配置,如目的地类型(队列或主题)、消息驱动适配器等。 - 可以通过`@ActivationConfigProperty`注解进一步配置MDB的行为,例如设置消息选择器、最大...

    基于Java的Message-Driven Bean EJB实例源代码.zip

    Java Message-Driven Bean(MDB)是企业级Java(EJB)技术的一部分,它主要用于处理Java消息服务(JMS)中的消息。在Java EE环境中,MDBs是无状态的bean,它们作为后台服务运行,监听消息队列或主题,并对到来的消息...

    Message-Driven Bean EJB实例源代码.rar

    1. **MDB类定义**:MDB类需要实现 javax.jms.MessageListener 接口,并且通常会带有 @MessageDriven 注解。例如: ```java import javax.ejb.MessageDriven; import javax.jms.MessageListener; import javax.jms....

    基于Java的源码-Message-Driven Bean EJB实例源代码.zip

    Message-Driven Bean是一种特殊的session bean,它以事件驱动的方式工作,专门用于接收和处理JMS消息。当消息队列中有新消息到达时,MDB会自动激活,处理消息,然后返回到等待状态。这种模式在处理大量并发请求或者...

    Message-Driven Bean EJB实例源代码.7z

    7. **部署**:在EJB 3.1及更高版本中,MDB的部署变得更加简单,可以使用注解(如`@MessageDriven`)来代替XML配置,进一步简化了开发过程。 在这个源代码实例中,你可能会看到以下几个关键部分: 1. **MDB类**:...

    基于Java的实例开发源码-Message-Driven Bean EJB实例源代码.zip

    "基于Java的实例开发源码-Message-Driven Bean EJB实例源代码.zip" 这个标题揭示了本次讨论的核心内容,即一个关于Java编程的实例项目,特别是涉及了Java企业版(Java EE)中的Message-Driven Bean(MDB)组件。...

    Message-Driven Bean 培训PPT

    MDB(Message-Driven Bean)是一种特殊的EJB,它被设计用来处理来自JMS的消息。MDB具有特定的生命周期,包括创建、激活和销毁阶段。当一个MDB实例被创建时,它会被激活并准备好接收消息。当不再需要时,MDB会被销毁...

    EJB3中MessageDrivenBean知识

    在EJB3中,创建一个MDB非常简单,只需要在bean类上添加`@MessageDriven`注解,并指定消息驱动的类型,如`@ActivationConfigProperty(propertyName = "destinationType", propertyValue = "javax.jms.Queue")`来定义...

    ejb状态bean和消息bean的源代码

    状态Bean和消息Bean在实际应用中常常结合使用。例如,一个在线购物系统可能使用状态Bean来跟踪用户的购物车状态,而消息Bean则用于处理后台的订单处理流程,如库存检查、发货通知等。通过这种方式,状态Bean负责与...

    JMS与MDB介绍

    MDB(Message Driven Bean)是Java EE中处理JMS消息的组件,实现了消息驱动的并发处理,增强了系统可扩展性和解耦性。理解并掌握JMS和MDB的使用,对于构建高效、可靠的Java企业级应用至关重要。

    JMS和MDB的实例代码

    在IT行业中,Java消息服务(Java Message Service,简称JMS)和Message Driven Bean(MDB)是企业级应用开发中的重要组件,尤其在处理异步通信和解耦系统间依赖时发挥着关键作用。本文将深入探讨JMS和MDB的概念、...

    ejb3进阶案例

    ejb3进阶案例的TestEjb3可能包含测试用例和集成测试,用于验证Session Bean、实体Bean和MessageDriven Bean的功能是否正常工作。这些测试用例通常会使用JUnit或Arquillian等工具,模拟客户端调用并检查结果。 总结...

    EJB容器对bean的管理

    消息驱动bean(Message driven bean,MDB)专门用于处理JMS消息。每个MDB都有自己的实例池。当JMS客户端发送消息时,EJB容器会从池中选取一个实例来处理消息。处理完成后,实例返回池中等待下一次消息。这种机制确保...

Global site tag (gtag.js) - Google Analytics