消息中间件及mq基础

上传人:第*** 文档编号:32763083 上传时间:2018-02-12 格式:DOC 页数:7 大小:85KB
返回 下载 相关 举报
消息中间件及mq基础_第1页
第1页 / 共7页
消息中间件及mq基础_第2页
第2页 / 共7页
消息中间件及mq基础_第3页
第3页 / 共7页
消息中间件及mq基础_第4页
第4页 / 共7页
消息中间件及mq基础_第5页
第5页 / 共7页
点击查看更多>>
资源描述

《消息中间件及mq基础》由会员分享,可在线阅读,更多相关《消息中间件及mq基础(7页珍藏版)》请在金锄头文库上搜索。

1、消息中间件及 WebSphere MQ 消息中间件概述消息队列技术是分布式应用间交换信息的一种技术。消息队列可驻留在内存或磁盘上,队列存储消息直到它们被应用程序读走。通过消息队列,应用程序可独立地执行-它们不需要知道彼此的位置、或在继续执行前不需要等待接收程序接收此消息。在分布式计算环境中,为了集成分布式应用,开发者需要对异构网络环境下的分布式应用提供有效的通信手段。为了管理需要共享的信息,对应用提供公共的信息交换机制是重要的。设计分布式应用的方法主要有:远程过程调用(PRC)-分布式计算环境(DCE)的基础标准成分之一;对象事务监控 (OTM)-基于 CORBA的面向对象工业标准与事务处理(

2、TP)监控技术的组合;消息队列(MessageQueue)- 构造分布式应用的松耦合方法。(a) 分布计算环境/远程过程调用 (DCE/RPC)RPC 是 DCE 的成分,是一个由开放软件基金会(OSF)发布的应用集成的软件标准。RPC 模仿一个程序用函数引用来引用另一程序的传统程序设计方法,此引用是过程调用的形式,一旦被调用,程序的控制则转向被调用程序。在 RPC 实现时,被调用过程可在本地或远地的另一系统中驻留并在执行。当被调用程序完成处理输入数据,结果放在过程调用的返回变量中返回到调用程序。RPC 完成后程序控制则立即返回到调用程序。因此 RPC 模仿子程序的调用/返回结构,它仅提供了

3、Client(调用程序) 和 Server(被调用过程)间的同步数据交换。(b) 对象事务监控 (OTM)基于 CORBA 的面向对象工业标准与事务处理(TP)监控技术的组合,在 CORBA 规范中定义了:使用面向对象技术和方法的体系结构;公共的 Client/Server 程序设计接口;多平台间传输和翻译数据的指导方针;开发分布式应用接口的语言(IDL)等,并为构造分布的 Client/Server 应用提供了广泛及一致的模式。(c) 消息队列 (Message Queue)消息队列为构造以同步或异步方式实现的分布式应用提供了松耦合方法。消息队列的 API 调用被嵌入到新的或现存的应用中,通

4、过消息发送到内存或基于磁盘的队列或从它读出而提供信息交换。消息队列可用在应用中以执行多种功能,比如要求服务、交换信息或异步处理等。中间件是一种独立的系统软件或服务程序,分布式应用系统借助这种软件在不同的技术之间共享资源,管理计算资源和网络通讯。它在计算机系统中是一个关键软件,它能实现应用的互连和互操作性,能保证系统的安全、可靠、高效的运行。中间件位于用户应用和操作系统及网络软件之间,它为应用提供了公用的通信手段,并且独立于网络和操作系统。中间件为开发者提供了公用于所有环境的应用程序接口,当应用程序中嵌入其函数调用,它便可利用其运行的特定操作系统和网络环境的功能,为应用执行通信功能。如果没有消息

5、中间件完成信息交换,应用开发者为了传输数据,必须要学会如何用网络和操作系统软件的功能,编写相应的应用程序来发送和接收信息,且交换信息没有标准方法,每个应用必须进行特定的编程从而和多平台、不同环境下的一个或多个应用通信。例如,为了实现网络上不同主机系统间的通信,将要求具备在网络上如何交换信息的知识(比如用 TCP/IP 的 socket 程序设计);为了实现同一主机内不同进程之间的通讯,将要求具备操作系统的消息队列或命名管道(Pipes)等知识。目前中间件的种类很多,如交易管理中间件(如 IBM 的 CICS)、面向 Java 应用的 Web 应用服务器中间件(如 IBM 的 WebSphere

6、 Application Server)等,而消息传输中间件(MOM) 是其中的一种。它简化了应用之间数据的传输,屏蔽底层异构操作系统和网络平台,提供一致的通讯标准和应用开发,确保分布式计算网络环境下可靠的、跨平台的信息传输和数据交换。它基于消息队列的存储-转发机制,并提供特有的异步传输机制,能够基于消息传输和异步事务处理实现应用整合与数据交换。IBM 消息中间件 MQ 以其独特的安全机制、简便快速的编程风格、卓越不凡的稳定性、可扩展性和跨平台性,以及强大的事务处理能力和消息通讯能力,成为业界市场占有率最高的消息中间件产品。MQ 具有强大的跨平台性,它支持的平台数多达 35 种。它支持各种主流

7、 Unix 操作系统平台,如:HP-UX、AIX、SUN Solaris、Digital UNIX、Open VMX、SUNOS、NCR UNIX;支持各种主机平台,如:OS/390、MVS/ESA、VSE/ESA ;同样支持 Windows NT 服务器。在 PC 平台上支持Windows9X/Windows NT/Windows 2000 和 UNIX (UnixWare、Solaris)以及主要的 Linux 版本(Redhat、TurboLinux 等) 。此外,MQ 还支持其他各种操作系统平台,如:OS/2、AS/400、Sequent DYNIX、SCO OpenServer、SC

8、O UnixWare、Tandem 等。MQ 的基本概念:1) 队列管理器队列管理器是 MQ 系统中最上层的一个概念,由它为我们提供基于队列的消息服务。2) 消息在 MQ 中,我们把应用程序交由 MQ 传输的数据定义为消息,我们可以定义消息的内容并对消息进行广义的理解,比如:用户的各种类型的数据文件,某个应用向其它应用发出的处理请求等都可以作为消息。消息有两部分组成:消息描述符(Message Discription 或 Message Header),描述消息的特征,如:消息的优先级、生命周期、消息 Id 等;消息体(Message Body),即用户数据部分。在 MQ 中,消息分为两种类型

9、,非永久性(non-persistent)消息和永久性(persistent)消息,非永久性消息是存储在内存中的,它是为了提高性能而设计的,当系统掉电或 MQ 队列管理器重新启动时,将不可恢复。当用户对消息的可靠性要求不高,而侧重系统的性能表现时,可以采用该种类型的消息,如:当发布股票信息时,由于股票信息是不断更新的,我们可能每若干秒就会发布一次,新的消息会不断覆盖旧的消息。永久性消息是存储在硬盘上,并且纪录数据日志的,它具有高可靠性,在网络和系统发生故障等情况下都能确保消息不丢、不重。此外,在 MQ 中,还有逻辑消息和物理消息的概念。利用逻辑消息和物理消息,我们可以将大消息进行分段处理,也可

10、以将若干个本身完整的消息在应用逻辑上归为一组进行处理。3) 队列队列是消息的安全存放地,队列存储消息直到它被应用程序处理。消息队列以下述方式工作:a) 程序 A 形成对消息队列系统的调用,此调用告知消息队列系统,消息准备好了投向程序 B;回页首b) 消息队列系统发送此消息到程序 B 驻留处的系统,并将它放到程序 B 的队列中;c) 适当时间后,程序 B 从它的队列中读此消息,并处理此信息。由于采用了先进的程序设计思想以及内部工作机制,MQ 能够在各种网络条件下保证消息的可靠传递,可以克服网络线路质量差或不稳定的现状,在传输过程中,如果通信线路出现故障或远端的主机发生故障,本地的应用程序都不会受

11、到影响,可以继续发送数据,而无需等待网络故障恢复或远端主机正常后再重新运行。在 MQ 中,队列分为很多种类型,其中包括:本地队列、远程队列、模板队列、动态队列、别名队列等。本地队列又分为普通本地队列和传输队列,普通本地队列是应用程序通过 API 对其进行读写操作的队列;传输队列可以理解为存储 -转发队列,比如:我们将某个消息交给 MQ 系统发送到远程主机,而此时网络发生故障,MQ 将把消息放在传输队列中暂存,当网络恢复时,再发往远端目的地。远程队列是目的队列在本地的定义,它类似一个地址指针,指向远程主机上的某个目的队列,它仅仅是个定义,不真正占用磁盘存储空间。模板队列和动态队列是 MQ 的一个

12、特色,它的一个典型用途是用作系统的可扩展性考虑。我们可以创建一个模板队列,当今后需要新增队列时,每打开一个模板队列,MQ 便会自动生成一个动态队列,我们还可以指定该动态队列为临时队列或者是永久队列,若为临时队列我们可以在关闭它的同时将它删除,相反,若为永久队列,我们可以将它永久保留,为我所用。4) 通道通道是 MQ 系统中队列管理器之间传递消息的管道,它是建立在物理的网络连接之上的一个逻辑概念,也是 MQ 产品的精华。在 MQ 中,主要有三大类通道类型,即消息通道,MQI 通道和 Cluster 通道。消息通道是用于在 MQ 的服务器和服务器之间传输消息的,需要强调指出的是,该通道是单向的,它

13、又有发送(sender), 接收 (receive), 请求者(requestor), 服务者(server)等不同类型,供用户在不同情况下使用。MQI通道是 MQ Client 和MQ Server 之间通讯和传输消息用的,与消息通道不同,它的传输是双向的。群集(Cluster)通道是位于同一个 MQ 群集内部的队列管理器之间通讯使用的。MQ 的工作原理回页首如图所示:首先来看本地通讯的情况,应用程序 A 和应用程序 B 运行于同一系统 A,它们之间可以借助消息队列技术进行彼此的通讯:应用程序A 向队列 1 发送一条信息,而当应用程序 B 需要时就可以得到该信息。其次是远程通讯的情况,如果信

14、息传输的目标改为在系统 B 上的应用程序 C,这种变化不会对应用程序 A 产生影响,应用程序 A 向队列 2 发送一条信息,系统A 的 MQ 发现 Q2 所指向的目的队列实际上位于系统 B,它将信息放到本地的一个特殊队列传输队列(Transmission Queue)。我们建立一条从系统 A 到系统 B的消息通道,消息通道代理将从传输队列中读取消息,并传递这条信息到系统 B,然后等待确认。只有 MQ 接到系统 B 成功收到信息的确认之后,它才从传输队列中真正将该信息删除。如果通讯线路不通,或系统 B 不在运行,信息会留在传输队列中,直到被成功地传送到目的地。这是 MQ 最基本而最重要的技术-确

15、保信息传输,并且是一次且仅一次(once-and-only-once)的传递。MQ 提供了用于应用集成的松耦合的连接方法,因为共享信息的应用不需要知道彼此物理位置(网络地址);不需要知道彼此间怎样建立通信;不需要同时处于运行状态;不需要在同样的操作系统或网络环境下运行。MQ 的基本配置举例在上图中,要实现网络上两台主机上的通讯,若采用点对点的通讯方式,我们至少要建立如下 MQ 的对象:在发送方 A:1) 建立队列管理器 QMA: crtmqm -q QMA2) 定义本地传输队列: define qlocal (QMB) usage (xmitq) defpsist(yes)回页首3) 创建远程

16、队列 : define qremote (QR.TOB) rname (LQB) rqmname (QMB) xmitq (QMB)4) 定义发送通道 : define channel (A.TO.B) chltype (sdr) conname (IP of B) xmitq (QMB) + trptype (tcp)在接收方 B:1) 建立队列管理器 QMB: crtmqm -q QMB2) 定义本地队列 QLB: define qlocal (LQB)3) 创建接收通道 : define channel (A.TO.B) chltype (rcvr) trptype (tcp)经过上述配置,我们就可以实现从主机 A 到 B 的单向通讯,若要实现二者之间的双向通讯,可参考此例创建所需要的 MQ 对象。MQ 的通讯模式1) 点对点通讯:点对点方式是最为传统和常见的通讯方式,它支持一对一、一对多、多对多、多对一等多种配置方式,支持树状、网状等多种拓扑结构。2) 多点广播:MQ 适用于不同类型的应用。其中重要的,也是正在发展

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 工程造价

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号