第七章TUXEDO的可靠消息队列Q.doc

  1. 1、本文档共31页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第七章TUXEDO的可靠消息队列Q.doc

第七章:TUXEDO的可靠消息队列/Q 10.1 /Q介绍 /Q是Tuxedo系统的一个重要组成部分,它提供了一种可靠队列机制,允许消息按某种排队规则存储到磁盘上或内存中,然后再转发给其它进程。这种存储转发机制可以保证在两个通信实体之间传递的消息不丢失、不重传,从而保证交易的完整性。TUXEDO /Q提供管理工具和编程接口用于对/Q进行管理和操作。 名词解释: /Q 指TUXEDO的可靠消息队列,是TUXEDO产品的一个组成部分,功能类似于IBM的 MQSeries,BEA MessageQ等其他消息中间件。 MESSAGE 消息,存储在QUEUE中的数据称为消息(MESSAGE),一个QUEUE中可以有多条消息.对QUEUE的操作是以消息为单位的,即以次只能发送或取出一条消息。 QUEUE 队列,用于保存发送来的消息,以便随后的处理,一个QUEUE中可以同时存在多条消息。 QUEUE SPACE 队列空间,是QUEUE的一个集合,以便进行统一管理,一个QUEUE SPACE中可包含多个QUEUE。 TMQUEUE TUXEDO带的一个SERVER,接收用tpenqueue()发送来的消息.并把他们保存到相应的 QUEUE中,接受并处理tpdequeue()的请求。 TMQFORWARD TUXEDO带的一个SERVER,从一个QUEUE中取数据,然后调用一个与该QUEUE同名的 SERVICE进行处理,并把该SERVICE返回的结果发送到另一个QUEUE中。 TMS_QM 是与/Q资源管理器对应的TMS(TRANSACTION MANAGER SERVER),它使对 消息的发送与取出操作可以以事务的方式进行.并使/Q资源管理器可参与全局事务。 /Q的组成 /Q系统 /Q系统 MESSAGE QUEUEQUEUE SPACE MESSAGE QUEUE QUEUE SPACE MESSAGE QUEUE QUEUE SPACE /Q的使用方式 图中左侧为TUXEDO客户端,右侧为TUXEDO事务管理器/T,中间为TUXEDO可靠消息队列系统/Q。右侧事务管理器/T提供了两个服务:SERVICE1和SERVICE2。在消息队列系统/Q中,一个QUEUE SPACE对应一个GROUP, TMS_QM是/Q的事务管理进程,在该GROUP中要进行定义,该QUEUE SPACE中定义了有四个消息队列,SERVICE1和SERVICE2分别是对应于同名的两个服务(SERVICE)的队列(这是一种习惯的命名规则,客户机若请求服务器中的SERVICE1服务,就把请求消息放入SERVICE1队列中)。SERVICE1的处理结果放到CLIENT_RPLY1中,如果SERVICE1,SERVICE2在处理过程中发生错误, 把错误信息保存到队列FAILUREQ中。 /Q有两种使用方式,我们称之为基本模式和转发模式 基本模式: 只用到TMQUEUE,不使用TMQFORWARD,不调用SERVICE对QUEUE中的消息进行处理。流程说明如下(不需要进行4-7的操作,也不需要定义与QUEUE同名的SERVICE): 1. 客户端调用tpenqueue()把数据发送到SERVICE1 2. TMQUEUE接收tpenqueue()发送来的数据,并把他们保存到SERVICE1中 3. 如果以上操作成功,那么tpenqueue()返回成功. 8. 客户端调用tpdequeue(),请求从SERVICE1中取数据 10. TMQUEUE收到该请求,它把相应的消息从SERVICE1中取出,并发送给客户端 转发模式: 用到TMQUEUE和TMQFORWARD,要定义与QUEUE同名的SERVICE并调用SERVICE对QUEUE中的消息进行处理。流程说明如下: 1. 客户端调用tpenqueue()把消息发送到SERVICE1 2. TMQUEUE接收tpenqueue()发送来的消息,并把他们保存到SERVICE1中 3. 如果以上操作成功,那么tpenqueue()返回成功. 4. TMQFORWARD在某个设定的时刻,从SERVICE1中取消息 5. TMQFORWARD用事务模式调用(采用TPCALL())一个名为 SERVICE1 的SERVICE,将 消息转发给SERVICE1 6. 名为 SERVICE1 的SERVICE 把处理的结果用tprerurn()返回给TPQFORWARD. 7. TPQFORWARD把收到的处理结果发送到REPLYQ 8. 客户端调用tpdequeue(),请求从REPLYQ中取回响应消息 9. TMQUEUE收到该请求,它把相应的消息从que

您可能关注的文档

文档评论(0)

sunguohong + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档