`
tonney_lee
  • 浏览: 25722 次
  • 性别: Icon_minigender_1
  • 来自: 浙江.杭州
最近访客 更多访客>>
社区版块
存档分类
最新评论

Java Message Service 学习(二)(概念和体系)

    博客分类:
  • Java
阅读更多
 

JMS 应用程序由以下元素组成:

  • JMS 客户机。 用 JMS API 发送和接收消息的 Java 程序。

  • 非 JMS 客户机。 认识到传统程序通常整个 JMS 应用程序的一部分是非常重要的,在规划时必须优先考虑它们的存在。

  • 消息。就JMS 应用程序设计而言,通过JMS 和非 JMS 客户机所交换的消息的格式和内容是完整的。

  • JMS 提供者。 如前所述,JMS 定义了一组接口,供应者必须提供特定于其 MOM 产品的具体实现。

  • 管理对象。 消息系统提供者的管理员创建的、独立于提供者的专有技术的对象。

 

MOM 产品的提供者在实现消息时使用的机制和技术有很大不同。为了保持 JMS 客户机的可移植性,实现了 JMS 接口的对象必须与提供者的专有技术隔离。

完成这项任务的机制是 管理对象。这些实现 JMS 接口的对象由提供者的消息系统的管理员创建,并被放置在 JNDI 名字空间中。

然后由 JMS 程序检索这些对象,通过它们实现的 JMS 接口访问这些对象。JMS 提供者必须提供允许创建受管理对象及它们在 JNDI 名字空间中的存放地的工具。

有两种受管理对象:

  • ConnectionFactory:用于创建到提供者的底层消息系统的连接。

  • Destination:用 JMS 客户机来指定正发送消息的目的地或正接收消息的来源。

 

尽管受管理对象本身就是特定于提供者实现的类的例子,但可以使用可移植机制(JNDI)检索它们,并且可以通过可移植接口(JMS)访问它们。JMS 程序只需要知道管理对象的 JNDI 名称和 JMS 接口类型即可,无需了解特定于提供者的知识。

 

 

JMS 定义了一组封装各种消息概念的高级接口。而这些接口又因为两个消息域——PTP 和 pub/sub——进行了进一步地定义和定制。

高级接口包括:

  • ConnectionFactory:一个创建 Connection 的受管理对象。

  • Connection:连接到提供者的活动连接。

  • Destination:一个封装消息目的地的身份的受管理对象,如消息的来源地和发送地。

  • Session:发送和接收消息的单线程环境。为了简化,并且因为 Session 控制事务的缘故,通过多个线程进行并发访问受到了限制。可以将多个 Session 用于多线程应用程序。

  • MessageProducer:用于发送消息。

  • MessageConsumer:用于接收消息。

 

下表列出了从每一个高级接口继承的特定于域的接口。

高级接口 PTP 域 Pub/sub 域
ConnectionFactory QueueConnectionFactory TopicConnectionFactory
Connection QueueConnection TopicConnection
Destination Queue Topic
Session QueueSession TopicSession
MessageProducer QueueSender TopicPublisher
MessageConsumer QueueReceiverQueueBrowser TopicSubscriber

 

一个典型的 JMS 程序要经过以下步骤才能开始产生和使用消息:

  1. 通过 JNDI 查询 ConnectionFactory

  2. 通过 JNDI 查询一个或者多个 Destination

  3. ConnectionFactory 创建一个 Connection

  4. Connection 创建一个或者多个 Session

  5. SessionDestination 创建所需要的 MessageProducerMessageConsumer

  6. 启动 Connection

 

JMS 为不同类型的内容提供了几种消息类型,但所有消息都是从 Message 接口派生出来的。

Message 分为三个组成部分:

  • header 是一组标准字段,客户机和提供者都用它们来标识和路由消息。

  • Properties 提供了一个给消息添加可选标题字段的实用工具。如果应用程序需要用标准标题字段没有提供的方法对消息进行归类或分类,那么可以为消息添加一个属性来实现这种归类和分类;提供了 set<Type>Property(...)get<Type>Property(...) 方法来设置和获得各种 Java 类型的属性,其中包括 Object。JMS 定义了提供者可以选择性提供的一组标准属性。

  • 消息的 body 包含将 发送到接收应用程序的内容。每一个消息接口都专用于它所支持的内容类型。

 

 

header字段


下面列出了 Message 的每一个标题字段的名称、它对应的 Java 类型和字段的描述:

  • JMSMessageID——类型为 string

    惟一标识提供者发送的每一条消息。这个字段是在发送过程中由提供者设置的,客户机只能在消息发送后才能确定消息的 JMSMessageID

  • JMSDestination——类型为 Destination

    消息发送的 Destination,在发送过程中由提供者设置。

  • JMSDeliveryMode——类型为 int

    包含值 DeliveryMode.PERSISTENT 或者 DeliveryMode.NON_PERSISTENT。持久性消息被传输并且只被传输一次,非持久性消息最多被传输一次。要知道“最多一次”包括根本不传输。非持久性消息在应用程序或者系统出故障时被提供者弄丢。因此要格外小心,确保持久性消息不受故障的影响。这比开销通常被认为是发送持久性消息方面的开销,在决定消息的发送模式时,必须仔细考虑,在可靠性和性能之间进行权衡。

  • JMSTimestamp——类型为 long

    提供者发送消息的时间,由提供者在发送过程中设置。

  • JMSExpiration——类型为 long

    消息失效的时间。这个值是在发送过程中计算的,是发送方法的生存时间(time-to-live)值和当前时间值的和。提供者不应发送过期的消息。值 0 表明消息不会过期。

  • JMSPriority——类型为 int

    消息的优先级,由提供者在发送过程中设置。优先级 0 的优先级最低,优先级 9 的优先级最高。

  • JMSCorrelationID——类型为 string

    通常用来链接响应消息与请求消息,由发送消息的 JMS 程序设置。响应来自另一个 JMS 程序的消息的 JMS 程序将正响应消息的 JMSMessageID 拷贝到这个字段中,这样,正作出响应的程序就可以与它所发出的特定请求的响应相 关联

  • JMSReplyTo——类型为 Destination

    请求程序用它来指出回复消息应发送的地方,由发送消息的 JMS 程序设置。

  • JMSType——类型为 string

    JMS 程序用它来指出消息的类型。一些提供者维护着一个消息类型仓库,并用该字段引用仓库中的定义类型,在这里,JMS 程序不应该使用这个字段。

  • JMSRedelivered——类型为 boolean

    指出消息被过早地发送给了 JMS 程序,程序不知道消息的接收者是谁;由提供者在接收过程中设置。

 

 

有五种消息正文格式,每一种格式都是由一个扩展 Message 的接口定义的。这些接口是:

  • StreamMessage:包含一组 Java 原始值,这些值是通过标准流操作按顺序进行填充和读取的。

  • MapMessage:包含一组名称-值( name-value )对,其中名称是 string 的类型,值是 Java 原始值。

  • TextMessage:包含一个String

  • ObjectMessage:包含一个Serializable Java 对象,可以使用 JDK 1.2 的 collection类。

  • BytesMessage:包含一些未解释字节;允许对正文进行编码来匹配现有的消息格式。

 

每一个提供者都提供了一些特定于实现这些接口的其产品的类。一定要注意的是, JMS 规范命令提供者必须准备接收和处理不属于它自己的 Message 类的实例的 Message 对象。

尽管提供者处理这些“外来”对象时不能像处理自己对象那样有效,但他们必须处理这些对象来确保与所有 JMS 提供者的互操作性。

 

 

分享到:
评论

相关推荐

    传智播客全套Java体系ppt

    4. **Java EE企业级开发**:Java EE是Java在企业级应用中的高级平台,包括EJB(Enterprise JavaBeans)、JMS(Java Message Service)、JPA(Java Persistence API)等技术。学习Java EE意味着要理解分布式系统、...

    java web方向学习曲线图

    进一步的分布式开发技术涉及JTA(Java Transaction API)、JAAS(Java Authentication and Authorization Service)、JNDI(Java Naming and Directory Interface)、JavaMail、JMS(Java Message Service)以及...

    java学习路线图,专为新手制定的java学习计划

    除此之外,还有JNDI(Java Naming and Directory Interface)、RMI(Remote Method Invocation)、JMS(Java Message Service)、JAVA IDL、JTS、JTA、JAVAMAIL、JAF、Log4j、JUnit、Freemarker和Velocity等技术。...

    java的30个学习目标

    深入理解面向对象分析与设计是Java学习的基石,这不仅包括掌握基本概念,还应熟练运用GoF(Gang of Four)设计模式和J2EE设计模式(J2EEDP),以及综合模式的灵活应用。这些模式如单例模式、工厂模式、策略模式等,能够...

    Java分布式应用学习笔记01分布式Java应用和SOA

    4. **JMS(Java Message Service)**:Java消息服务提供了一种与语言无关的API,用于在分布式环境中发送和接收消息。 5. **JPA(Java Persistence API)**:用于管理数据库持久化操作,简化了对象到关系的映射过程。...

    史上最全JavaEE基础体系图解(xmind).xmind

    这个史上最全的JavaEE基础体系图解涵盖了从基本概念到核心组件的广泛知识,是学习JavaEE不可或缺的参考资料。 1. **JavaEE概述** JavaEE是Sun Microsystems(现已被Oracle收购)推出的一种标准,用于构建企业级...

    Java EE期末考试试题

    它提供了一系列的API和服务,包括Servlet、JSP、EJB(Enterprise JavaBeans)、JMS(Java Message Service)等,使得开发者能够方便地开发、部署和管理Web应用、企业应用和后端服务。 1. **Servlet**: Servlet是...

    如何学习java web开发

    2. **JMS(Java Message Service)**:一种消息传递机制,用于不同应用程序之间的通信。 3. **RMI(Remote Method Invocation)/CORBA(Common Object Request Broker Architecture)**:学习远程对象调用和服务之间...

    Java相关技术(详细资料)

     7、JMS(Java Message Service)提供企业消息服务,如可靠的消息队列、发布和订阅通信、以及有关推拉(Push/Pull)技术的各个方面。  8、JTS(Java transaction Service)提供存取事务处理资源的开放标准,这些事务...

    java学习方向[参考].pdf

    2. 组件模型技术:Java Servlet、JSP(JavaServer Pages)、JSF(JavaServer Faces)、EJB(Enterprise JavaBeans)、JMS(Java Message Service)和JCA(J2EE Connector Architecture)。 3. 管理技术:J2EE部署...

    java学习路线

    - **JMS (Java Message Service)**:用于消息传递的标准API。 - **Web Services**:一种标准的远程服务调用协议。 - **SOA (Service-Oriented Architecture)**:面向服务的架构设计模式。 #### 四、数据库技术 ...

    达内java笔记,精挑细选(达内助教整理)0积分

    J2EE平台由多个组件构成,如Servlet、JSP(JavaServer Pages)、EJB(Enterprise JavaBeans)、JMS(Java Message Service)等。Servlet是处理HTTP请求的主要工具,JSP用于生成动态网页内容,而EJB则提供了服务器端...

    如何学习java--(牛人指点路线)

    - **JMS(Java Message Service)**:消息传递服务,允许应用程序通过消息进行异步通信。 - **JavaMail**:Java库,用于发送和接收电子邮件。 - **JDO(Java Data Objects)**:提供持久化服务,将Java对象存储到...

    JAVA入门: J2EE的学习流程

    在Java技术体系中,根据不同的应用场景和技术需求,Java主要分为三个版本:J2SE(Java 2 Platform Standard Edition)、J2ME(Java 2 Platform Micro Edition)以及J2EE(Java 2 Platform Enterprise Edition)。...

    java一定要看的资料

    J2EE(Java Platform, Enterprise Edition)和MVC(Model-View-Controller)篇讨论了Java在企业级开发中的应用,包括EJB(Enterprise JavaBeans)、JMS(Java Message Service)以及Spring框架的使用。MVC设计模式是...

    Java网络高级编程

    第8章介绍了异步消息服务技术JMS(Java Message Service)和Java Mail技术,JMS允许应用程序之间通过消息传递进行通信,而Java Mail则是用于电子邮件处理的API。第9章则聚焦于利用WebLogic服务器的EJB(Enterprise ...

    语言程序设计资料:Java开发体系结构讲解.ppt

    - **JMS(Java Message Service)**:消息传递API,实现应用程序之间的异步通信。 - **EJB(Enterprise JavaBeans)**:企业级组件,提供事务管理、安全性和状态管理等功能。 - **XML处理**:包括DOM(文档对象...

Global site tag (gtag.js) - Google Analytics