`

使用WEBLOGIC收发JMS

    博客分类:
  • Java
阅读更多

JMS是一个由AS提供的Message服务。它能接受消息产生者(Message Provider)所发出的消息,并把消息转发给消息消费者(Message  Consumer)。
2、JMS提供2种类型的消息服务:(1)Queue,即点对点,每个消息只转发给一个消息消费者使用。(2)Topic,即发布和订阅,每个消息可以转发给所有的订阅者(消费者)。
3、WEBLOGIC 8下的JMS配置:
(1)配置JMS Connection Factory
(2)配置JMS File Store(目前所找到的文档都是配置File Store,其实在具体的应用中,可能JMS JDBC Store更广泛,但暂时没有找到资料)
(3)配置JMS Server
(4)在JMS Server的destinations中配置JMS Queue或者JMS Topic
其中提供给消息产生者和消息消费者使用的是JMS Connection Factory的JNDI和JMS Queue或者JMS Topic的JNDI。
4、消息产生者向JMS发送消息的步骤:
(1)使用JNDI查询对象JMS ConnectionFactory和Destination(JMS Queue/Topic)
(2)使用管理对象JMS ConnectionFactory建立连接Connection
(3)使用连接Connection 建立会话Session
(4)使用会话Session和管理对象Destination创建消息生产者MessageSender
(5)使用消息生产者MessageSender发送消息
一个消息发送者的例子:

package myjms;   
  
import java.util.*;   
import javax.naming.*;   
import javax.jms.*;   
  
public class MessageProducter {   
  public static void main(String[] args) {   
    String queueConnectionFactoryName = "myjmsconnectionfactory"; //JMS Connection Factory?JNDI   
    String queueName = "myjmsqueue"; //JMS Queue??JMS Topic?JNDI   
  
    boolean transacted = false;//transaction??   
    int acknowledgementMode = Session.AUTO_ACKNOWLEDGE;//acknowledgement??   
    String message="Message need to send";//?????????   
  
    Properties properties = new Properties();   
    properties.put(Context.INITIAL_CONTEXT_FACTORY,"weblogic.jndi.WLInitialContextFactory");   
    properties.put(Context.PROVIDER_URL, "t3://localhost:7001");   
  
    try {   
      Context context = new InitialContext(properties);   
      Object obj = context.lookup(queueConnectionFactoryName);   
      QueueConnectionFactory queueConnectionFactory = (QueueConnectionFactory) obj;//JMS Connection Factory???   
        
      obj = context.lookup(queueName);   
      Queue queue = (Queue) obj;//JMS Queue??JMS Topic???   
  
      QueueConnection queueConnection=queueConnectionFactory.createQueueConnection();//????   
      queueConnection.start();   
      QueueSession queueSession = queueConnection.createQueueSession(transacted, acknowledgementMode);   
      TextMessage textMessage = queueSession.createTextMessage();   
      textMessage.clearBody();   
      textMessage.setText(message);   
      QueueSender queueSender = queueSession.createSender(queue);   
      queueSender.send(textMessage);   
      if (transacted) {   
        queueSession.commit();   
      }   
  
      if (queueSender != null) {   
        queueSender.close();   
      }   
      if (queueSession != null) {   
        queueSession.close();   
      }   
      if (queueConnection != null) {   
        queueConnection.close();   
      }   
  
    }   
    catch(Exception ex){   
      ex.printStackTrace();   
    }   
  }   
}  
 

5、消息消费者从JMS接受消息的步骤:
(1)使用JNDI查询对象JMS ConnectionFactory和Destination(JMS Queue/Topic)
(2)使用管理对象JMS ConnectionFactory建立连接Connection
(3)使用连接Connection 建立会话Session
(4)使用会话Session和管理对象Destination创建消息消费者MessageReceiver
(5)使用消息消费者MessageReceiver接受消息,需要用setMessageListener将MessageListener接口绑定到MessageReceiver
消息消费者必须实现了MessageListener接口,需要定义onMessage事件方法。
一个消息消费者的例子:

package myjms;   
  
import java.util.*;   
import javax.naming.*;   
import javax.jms.*;   
  
public class MessageReciever   
    implements MessageListener {   
  public void onMessage(Message message) {   
    if (message instanceof TextMessage) {   
      TextMessage textMessage = (TextMessage) message;   
      try {   
        System.out.println("Message content is:" + textMessage.getText());   
      }   
      catch (JMSException e) {   
        e.printStackTrace();   
      }   
    }   
  }   
  
  public static void main(String[] args) {   
      
    MessageReciever msgRcvr=new MessageReciever();   
    String queueConnectionFactoryName = "myjmsconnectionfactory";   
    String queueName = "myjmsqueue";   
  
    boolean transacted = false;   
    int acknowledgementMode = Session.AUTO_ACKNOWLEDGE;   
  
    Properties properties = new Properties();   
    properties.put(Context.INITIAL_CONTEXT_FACTORY,   
                   "weblogic.jndi.WLInitialContextFactory");   
    properties.put(Context.PROVIDER_URL, "t3://localhost:7001");   
  
    try {   
      Context context = new InitialContext(properties);   
      Object obj = context.lookup(queueConnectionFactoryName);   
      QueueConnectionFactory queueConnectionFactory = (QueueConnectionFactory)   
          obj;   
  
      obj = context.lookup(queueName);   
      Queue queue = (Queue) obj;   
  
      QueueConnection queueConnection = queueConnectionFactory.   
          createQueueConnection();   
      queueConnection.start();   
      QueueSession queueSession = queueConnection.createQueueSession(transacted,   
          acknowledgementMode);   
      QueueReceiver queueReceiver = queueSession.createReceiver(queue);   
  
      queueReceiver.setMessageListener(msgRcvr);   
  
      synchronized(msgRcvr){   
        msgRcvr.wait(100000);   
      }   
  
      if (queueReceiver != null) {   
        queueReceiver.close();   
      }   
      if (queueSession != null) {   
        queueSession.close();   
      }   
      if (queueConnection != null) {   
        queueConnection.close();   
      }   
  
    }   
    catch (Exception ex) {   
      ex.printStackTrace();   
    }   
  }   
}  

 6、Message-driven Bean
MDB实际上就是一个消息消费者的客户端程序。它由AS EJB Container来管理。在JBUILDER生成一个MDB非常简单。

分享到:
评论

相关推荐

    一种基于JMS和XML的大型矩阵分布式计算系统的设计方案.pdf

    本文采用了WebLogic 7.0作为JMS服务器,其支持JMS规范,能够处理任务队列和结果队列的消息收发工作。 运算器部分由若干台PC组成,每台PC执行矩阵子块的计算任务。计算模块统一采用优化的算法,以提高计算效率。运算...

    bolid_jms:Apka w ejb + jms 监听来自汽车的事件并处理

    6. **部署与配置**:EJB和JMS的集成通常涉及在应用服务器(如Tomcat、WildFly或WebLogic)中部署EJB组件,并配置JMS资源。这包括定义目的地(如队列或主题)、连接工厂和消息驱动bean的配置。 7. **异常处理与事务...

    h_JAVA 2应用编程150例.rar

    实例119 Request-Reply模式的JMS应用 421 实例120 使用Java IDL 426 实例121 EJB与CORBA的交互 430 实例122 基于EJB的真实世界模型 433 实例123 EJB的商业应用——定购单 447 第11章 Java 2 Platform Micro Edition...

    J2EE的13种核心技术

    - **定义**:JavaMail 提供了邮件收发功能的API。 - **应用场景**:发送电子邮件通知、激活链接等。 13. **JAF (Java Authentication and Authorization Service)** - **定义**:JAF 提供了一种机制来控制对应用...

    J2EE核心技术

    8. **JMS (Java Message Service)**:JMS提供了标准的API来发送和接收消息,实现异步通信和解耦应用组件。 9. **JAVAIDL (Java Interface Definition Language)**:JAVAIDL用于定义CORBA(Common Object Request ...

    J2EE教程

    4. **Java Message Service (JMS)**:JMS提供了面向消息中间件的API,使得开发者能够轻松地在分布式环境中发送和接收消息。 5. **Java Database Connectivity (JDBC)**:JDBC为Java应用程序提供了一种标准的访问...

    java应用软件程序设计

    Reply模式的JMS应用 421 实例120 使用Java IDL 426 实例121 EJB与CORBA的交互 430 实例122 基于EJB的真实世界模型 433 实例123 EJB的商业应用——定购单 447 第11章 Java 2 Platform Micro Edition...

    JAVA上百实例源码以及开源项目源代码

    EJB中JNDI的使用源码例子 1个目标文件,JNDI的使用例子,有源代码,可以下载参考,JNDI的使用,初始化Context,它是连接JNDI树的起始点,查找你要的对象,打印找到的对象,关闭Context…… ftp文件传输 2个目标文件...

Global site tag (gtag.js) - Google Analytics