`
lizhuang
  • 浏览: 903666 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论
阅读更多
一、消息术语
消息:
封装发送方及接收方之间传递的信息,包括消息主体 ( 数据 ) 、标头及可选的一些属性
标头:
         包含客户端及 JSM 提供程序所需的标识、路由消息的信息
         各种类型的消息都具有相同的标头结构
主体:
         包含具体的应用数据。
         据消息类型的不同有多种形式:简单文本字符串、 XML 、二进制流、已序列化的对象
被管理对象:
         在 JMS 应用程序之外产生并维护的对象,提供访问消息提供程序、连接已定义队列和主题的通用手段。使用 JNDI 来定位被管理对象。
连接:
         应用和 JMS 提供程序之间的链路
会话:
         用于对消息的收发过程进行管理
         它建立在连接之上,负责创建生产者和消费者、创建消息对象、处理事务、控制确认等
目的地 :
         JMS 消息的发送目标,可以是一个队列也可以是一个主题
队列:
         点到点模式下的目的地。消息被送进队列,然后被一个接收者取走
主题 :
         发布 / 订阅模式下的目的地。消息被送进主题,然后 JMS 提供程序将其拷贝分发给该主题的订阅者
生产者 :
         消息的来源。有两种生产者:发送者 (Sender) 和发布者 (Publisher) 。
         Sender 将消息发送到点到点模式下的队列
         Publisher 将消息发布到发布 / 订阅模式下的主题
消费者 :
         消息的接收者。有两种消费者:接收者 (Receiver) 和订阅者 (SubScriber)
         Receiver 从点到点模式下的队列中取走消息
         SubScriber 从发布 / 订阅模式下的主题中接收消息

二、接口概览
消息接口
Message:
         各类消息的基本接口。定义了消息的头、属性和主体
TextMessage:
         定义包含 String 对象的消息主体。用于基本的文本消息及包含 XML 的消息
BytesMessage:
         定义一个包含字节序列的消息主体。用于支持现有消息格式和非 Java 系统接口
ObjectMessage:
         定义包含可序列化 Java 对象的消息主体,只能包含一个对象。如果需要发送多个对象,则需发送对象的集合
MapMessage:
         定义包含一张映射表的消息主体,该映射表以字符串为关键字,以 Java 对象为值。可通过名字和按顺序访问对象
StreamMessage:
         定义可作为 Java 对象流被访问的消息主体。访问它的方法与 java.io.DataInputStream 和 java.io.OutputStream 非常相似。用于写原语和对象序列

点到点接口
Queue:
         点到点消息的目的地。将消息发往队列,并在创建发送方和接收方的时候指明队列
QueueSender:
         发送消息到指定队列
QueueReceiver:
         从指定队列接收消息
QueueSession:
         为某一队列创建发送方、接收方及各种类型的消息
QueueConnection:
         建立与 JMS 提供程序的连接,用于为应用程序创建会话
QueueConnectionFactory:
         一个与具体提供程序相捆绑的类,用于创建与 JMS 提供程序的连接,常在 JNDI 名字空间中查找它

发布 / 订阅接口
Topic:
         发布 / 订阅消息的目标地址。对于某一主题允许有多个发布者和订阅者
TopicPublisher:
         发布消息到指定主题
TopicSubscriber:
           订阅某一主题,同时支持阻塞和非阻塞的 receive 调用,另外也提供对已注册消息监听器的异步调用
TopicSession:
         为指定的连接创建发布人、订阅人以及各种类型的消息
TopicConnection:
         建立与 JMS 提供程序的连接,用于为应用创建对话
TopicConnectionFactory:
         一个与具体提供程序相捆绑的类,用于创建与 JMS 提供程序的连接

三、操作流程概览
使用 JMS 可以分为两个阶段:初始化 和消息处理
初始化过程建立与消息提供程序的连接,创建目的地、发送方和接收方;
消息处理完成消息的发送和接收

JMS 的初始化包括如下步骤:
1.   查找一个连接工厂 (QueueConnectonFactory 和 TopicConnectionFactory)
2.   使用工厂创建连接 (QueueConnection 和 TopicConnection)
3.   在连接上创建会话 (QueueSession 和 TopicSession)
4.   查找一个目的地 (Queue 或者 Topic)
5.   使用目的地在会话上创建发送方和接收方 (QueueSender/QueueReceiver 或者 TopicPublisher/Subscriber)
6.   对于异步接收者 / 消费者,注册一个消息监听器,用于监听消息的到达

JMS 对象的初始化完成后,按以下步骤发送消息:
1.   在会话之上建立消息对象
2.   填充消息的内容
3.   通过发送方或生产者发送消息

JMS 对象的初始化完成后还可以按以下步骤接收消息
1.   对于同步接收方式,使用接收方或消费者接收下一条可获得的消息;
对于异步发送方式,调用所连接对象的 start 方法开始接收消息
2.   通过前面得到的 Message 对象的句柄,读取消息的内容并处理它
分享到:
评论

相关推荐

    javax.jms.jar

    Classes contained in javax.jms.jar: javax.transaction.xa.XAResource.class javax.jms.BytesMessage.class javax.jms.Message.class javax.jms.JMSException.class javax.jms.Destination.class javax.jms....

    PDS-17001_JMS583_Datasheet_(Rev._1.0)_JMS583_jmicron_jms583开发_

    **JMS583芯片详解** JMS583是一款由JMicron科技公司设计的高性能USB 3.1 Gen 2至PCIe Gen3x2桥接芯片,旨在为存储设备提供高速数据传输能力。这款芯片是针对现代数据密集型应用而优化的,如SSD固态硬盘和外部存储...

    java.jms.jar JMS需要的JAR包

    `javax.jms.jar` 文件中包含了如`javax.jms.Queue`, `javax.jms.Topic`, `javax.jms.MessageProducer`, `javax.jms.MessageConsumer`, `javax.jms.ConnectionFactory`等关键接口,以及其他辅助类和异常类,开发者...

    jms-1.1.jar(jms工具jar包)

    Java消息服务(Java Message Service,简称JMS)是Java平台中用于企业级应用间异步通信的标准接口。它提供了一种可靠的消息传递机制,允许应用程序创建、发送、接收和读取消息。`jms-1.1.jar` 是一个包含了JMS 1.1...

    javax.jms包,sun的JMS接口规范包

    Java消息服务(Java Message Service,简称JMS)是Java平台中用于企业级应用集成的API,它定义了一组标准接口,允许应用程序创建、发送、接收和读取消息。`javax.jms`包是JMS规范的核心部分,包含了各种与消息传递...

    JMS583 USB PCIE 桥接芯片方案

    **JMS583 USB转PCIE桥接芯片方案** JMS583是一款由JMicron科技公司设计的高效能USB到PCI Express (PCIe)桥接芯片,旨在为电子设备提供一种灵活的方式来实现高速数据传输。这款芯片能够将USB接口转换成PCIe接口,以...

    jms-1.1.jar

    《JMS 1.1 API详解与应用实践》 Java消息服务(Java Message Service,简称JMS)是Java平台中用于企业级应用间异步通信的一种标准接口。JMS 1.1是其一个重要的版本,它为分布式系统中的应用程序提供了一种可靠的...

    USB转SATA硬盘盒JMS583量产工具

    标题中的“USB转SATA硬盘盒JMS583量产工具”是指一种专门用于将USB接口转换为SATA接口的硬件设备,其中JMS583是该转换器的主控芯片。这种硬盘盒允许用户将传统的SATA硬盘通过USB接口连接到电脑上,方便数据迁移、...

    JMS583量产工具.zip

    【JMS583量产工具】是一款专门针对JMS583芯片进行批量生产操作的软件工具,主要用于USB闪存盘的制作与修复。这款工具的全称可能为"JMS583 Mass Production Tool",它允许用户一次性对多个JMS583芯片驱动的USB设备...

    javax.jms.jar下载

    javax.jms.BytesMessage.class javax.jms.Connection.class javax.jms.ConnectionConsumer.class javax.jms.ConnectionFactory.class javax.jms.ConnectionMetaData.class javax.jms.DeliveryMode.class javax.jms....

    JMS1.1规范(中文)

    Java消息服务(Java Message Service,简称JMS)是Java平台中用于企业级应用集成的API,主要用于在分布式环境中传递消息。JMS1.1规范是该API的一个版本,提供了标准接口,使得不同的消息中间件(Message Oriented ...

    USB3.0移动硬盘盒 JMS578 固件2018最新固件, G-Technology 移动硬盘盒固件 for JMS578

    标题中的“USB3.0移动硬盘盒 JMS578 固件2018最新固件, G-Technology 移动硬盘盒固件 for JMS578”揭示了这个压缩包文件主要关注的是一个特定型号的USB3.0移动硬盘盒,该盒子采用JMS578主控芯片,并且提供了2018年...

    javax.jms-1.1.jar

    `javax.jms-1.1.jar` 是一个Java Message Service(JMS)的API库,它属于Java标准版(Java Standard Edition, Java SE)的一部分。JMS是Java平台上的一个规范,用于在分布式环境中进行异步消息传递。这个库主要用于...

    JMS578多达13个固件打包升级工具包 可修改休眠时间

    文件包含: 13个不同固件 两个固件升级工具 其中一个是量产工具可以修改休眠时间和盒子信息 TRIM检查工具 有几个固件版本为全网首发,别人没有的资源 固件列表: JMS578_00.01.00.05 ...JMS578_254.02.03.09_NoUAS

    weblogic中使用JMS发送和接受消息

    WebLogic Server是一款由Oracle公司提供的企业级应用服务器,它支持Java Message Service (JMS) 规范,允许在分布式环境中可靠地发送和接收消息。JMS是Java平台上的标准接口,用于实现应用程序间的异步通信。本文将...

    Weblogic JMS 依赖jar包下载

    Weblogic JMS 依赖jar包是Oracle公司的中间件产品Weblogic Server中用于实现Java Message Service (JMS) 功能的关键组件。JMS是一种标准API,它允许应用程序在分布式环境中发送和接收消息,提供了异步通信的能力。在...

    JMS(JMS(JMS(JMS(

    JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS

    JMS577主控通刷固件

    标题“JMS577主控通刷固件”指的是针对希捷移动硬盘中采用JMS577主控芯片的固件更新解决方案。在IT领域,固件是存储在硬件设备上的软件部分,它控制设备的操作并提供与主机系统的交互。JMS577是一种常见的硬盘主控...

Global site tag (gtag.js) - Google Analytics