`

深入掌握JMS(一):JMS基础

阅读更多

一.JMS基本概念 

        JMS(Java Message Service) 即Java消息服务。它提供标准的产生、发送、接收消息的接口简化企业应用的开发。它支持两种消息通信模型:点到点(point-to-point)(P2P)模型和发布/订阅(Pub/Sub)模型。        P2P模型规定了一个消息只能有一个接收者;Pub/Sub 模型允许一个消息可以有多个接收者。对于点到点模型,消息生产者产生一个消息后,把这个消息发送到一个Queue(队列)中,然后消息接收者再从这个Queue中读取,一旦这个消息被一个接收者读取之后,它就在这个Queue中消失了,所以一个消息只能被一个接收者消费。 

        点到点模型不同,发布/订阅模型中,消息生产者产生一个消息后,把这个消息发送到一个Topic中,这个Topic可以同时有多个接收者在监听,当一个消息到达这个Topic之后,所有消息接收者都会收到这个消息。

        简单的讲,点到点模型和发布/订阅模型的区别就是前者是一对一,后者是一对多。 

 

二.几个重要概念 

        Destination:消息发送的目的地,也就是前面说的Queue和Topic。创建好一个消息之后,只需要把这个消息发送到目的地,消息的发送者就可以继续做自己的事情,而不用等待消息被处理完成。至于这个消息什么时候,会被哪个消费者消费,完全取决于消息的接受者。 

        Message:从字面上就可以看出是被发送的消息。它有下面几种类型: 

        a.StreamMessage:Java 数据流消息,用标准流操作来顺序的填充和读取。 

        b.MapMessage:一个Map类型的消息;名称为 string 类型,而值为 Java 的基本类型。 

        c.TextMessage:普通字符串消息,包含一个String。 

        d.ObjectMessage:对象消息,包含一个可序列化的Java 对象 

        e.BytesMessage:二进制数组消息,包含一个byte[]。 

        f.XMLMessage:  一个XML类型的消息。 

        最常用的是TextMessage和ObjectMessage。 

        Session:与JMS提供者所建立的会话,通过Session我们才可以创建一个Message。 

        Connection:与JMS提供者建立的一个连接。可以从这个连接创建一个会话,即Session。 

        ConnectionFactory:那如何创建一个Connection呢?这就需要下面讲到的ConnectionFactory了。通过这个工厂类就可以得到一个与JMS提供者的连接,即Conection。 

        Producer:消息的生产者,要发送一个消息,必须通过这个生产者来发送。 

        MessageConsumer:与生产者相对应,这是消息的消费者或接收者,通过它来接收一个消息。 

        前面多次提到JMS提供者,因为JMS给我们提供的只是一系列接口,当我们使用一个JMS的时候,还是需要一个第三方的提供者,它的作用就是真正管理这些Connection,Session,Topic和Queue等。

        通过下面这个简图可以看出上面这些概念的关系。

        ConnectionFactory---->Connection--->Session--->Message 

        Destination + Session------------------------------------>Producer 

        Destination + Session------------------------------------>MessageConsumer 

        那么可能有人会问: ConnectionFactory和Destination 从哪儿得到? 

        这就和JMS提供者有关了. 如果在一个JavaEE环境中, 可以通过JNDI查找得到, 如果在一个非JavaEE环境中,那只能通过JMS提供者提供给我们的接口得到了。

 

文章来源:http://www.cnblogs.com/guthing/archive/2010/06/12/1757125.html

分享到:
评论

相关推荐

    深入掌握JMS.doc

    【深入掌握JMS】 JMS(Java Message Service)是Java平台中用于消息传递的标准API,它定义了消息的创建、发送、接收规范,使得不同应用系统间的数据交换变得简单。JMS提供了两种消息通信模型:点对点(P2P)和发布/...

    深入掌握JMS——ActiveMQ 十一章

    ### 深入掌握JMS——ActiveMQ 十一章 #### JMS基本概念与重要知识点解析 **JMS(Java Message Service)简介** JMS(Java消息服务)是一种广泛应用于企业级应用中的消息中间件协议,它为应用程序提供了一种高效、...

    深入掌握 JMS(java message service)

    ### 深入掌握 JMS(Java Message Service) #### JMS 基础概念 - **JMS**(Java Message Service)是一种Java平台中的消息中间件技术标准,它定义了一套标准API,用于应用程序之间的消息传递。JMS的出现极大地简化...

    jms-1.1.jar

    《JMS 1.1.jar:Java消息服务与Maven的深度解析》 在Java开发领域,消息服务(Java Message Service,简称JMS)扮演着至关重要的角色,它为...理解和掌握JMS原理及操作,对于提升Java应用的稳定性和扩展性至关重要。

    深入掌握JMS深入掌握JMS

    【深入掌握JMS】 JMS(Java Message Service)是Java平台中用于企业级应用间进行异步消息传递的标准API。它定义了一套统一的接口,使得开发者能够使用各种不同的消息中间件产品,如ActiveMQ,无需关注底层实现的...

    深入掌握JMS-ActiveMQ

    JMS(Java Message Service) 即Java消息服务。它提供标准的产生、发送、接收消息的接口简化企业应用的开发。本资源为chm格式,深入介绍了ActiveMQ的应用。

    由浅入深学习、掌握JMS

    接着,**《深入掌握JMS》** 进一步探讨了JMS的高级特性,如消息选择器、消息组、消息优先级以及事务管理。这部分内容有助于读者解决更复杂的消息处理需求,例如实现特定条件的消息过滤,或者确保消息的有序处理。 *...

    JBOSS建立JMS应用实例

    一、JMS基础知识 1. 概念理解:JMS是Java平台中用于企业级消息传递的API,它定义了生产、发送、接收和消费消息的标准接口。 2. 消息模型:JMS支持两种消息模型——点对点(Point-to-Point)和发布/订阅(Publish/...

    Weblogic环境下JMS配置

    理解并掌握JMS的基本原理和WebLogic的相关配置,将有助于开发人员更好地利用这一强大的通信机制,实现高效的数据交换。通过阅读《Weblogic环境下JMS配置.doc》文档,可以获取更详细的步骤和配置示例,进一步提升对这...

    JMS学习笔记精心总结

    总的来说,JMS是构建高可用、分布式系统的重要工具,理解和掌握JMS对于提升Java开发者在企业级应用开发中的能力至关重要。通过深入学习和实践,我们可以更好地利用JMS来解决复杂系统的异步通信问题。

    JMS的中文教程(Java的消息驱动)

    对于深入理解和掌握J2EE架构的开发者来说,掌握JMS是非常重要的。 #### 二、JMS的目标与适用场景 - **目标**:JMS旨在提供一种与平台无关的API,用于访问消息中间件。它支持两种消息传递模式:点到点(Point-to-...

    一个简单的JMS客户端应用

    本篇文章将深入探讨一个简单的JMS客户端应用的实现及其关键知识点。 1. **JMS概述** JMS是Java平台的标准接口,允许开发者通过消息传递在不同的应用程序之间进行通信。它支持两种消息模型:点对点(Point-to-Point...

    一个很好的jms教程

    ### 一、JMS基础 1. **消息模型**:JMS支持两种基本的消息模型——点对点(Point-to-Point, PTP)和发布/订阅(Publish/Subscribe, Pub/Sub)。点对点模型中,消息从一个生产者发送到一个队列,由一个或多个消费者...

    JMS demo 及 资料

    在这个"JMS demo 及 资料"的压缩包中,我们可能找到了一些关于JMS的基础教程和示例代码,帮助初学者了解和掌握JMS的基本用法。 JMS的核心概念主要包括以下几个部分: 1. **消息**: 消息是JMS中的基本数据单元,它...

    jms中间件设计源代码下载.zip

    JMS(Java Message Service)是Java平台中用于创建和管理异步消息的标准API,它允许应用程序之间通过消息传递...通过深入研究这些内容,你不仅可以掌握JMS的基本概念,还能了解到如何在实际环境中部署和管理JMS系统。

    JMS管理与开发手册.pdf

    #### 三、掌握JMS:核心概念与实践 - **JMS概述**:章节介绍了JMS的基本原理,包括点到点(P2P)和发布/订阅(Pub/Sub)两种消息模型,以及如何通过JMS与其他企业级Java API协同工作,如JNDI(Java命名和目录接口)...

    SpringJMS示例代码

    - 消费者代码(Consumer)通常包含一个实现了`MessageListener`接口的类,这个类会被Spring容器自动初始化,并通过`<jms:listener-container>`配置绑定到特定的Destination。 6. **消息模型** SpringJMS支持两种...

    JMS 使用 ActiveMQ 传送文件

    **标题:“JMS 使用 ActiveMQ 传送文件”** 在IT领域,Java消息服务(Java ...通过这些知识点的学习和实践,开发者可以掌握使用JMS和ActiveMQ进行文件传输的核心技能,为构建可靠的、分布式的应用打下坚实的基础。

    JMS的一个非常好的demo

    **JMS(Java Message Service)** 是一个Java平台上的标准接口,用于在分布式环境中传递消息。它提供了一种可靠的、异步的通信机制,使得不同的应用程序之间可以通过消息进行通信,而无需直接相互依赖。JMS通常用于...

    jms整合spring工程

    **正文** 在IT行业中,Java消息服务(Java Message Service,JMS)是一种标准接口,用于在应用程序之间交换异步消息。它提供了一种可靠的消息...通过深入研究该项目,可以掌握JMS和Spring集成的关键技术和最佳实践。

Global site tag (gtag.js) - Google Analytics