- 1、本文档共20页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
* 第*页 第16章 Service Broker 本章概述 本章要点 本章内容 * 第*页 本章概述 当人们与朋友通电话时,可以立即与受话人取得联系。但是,当人们给朋友发送E-mail或信件时,虽然确定朋友能收到,但是并不能准确地知道朋友何时能收到E-mail或信件。前者是同步通信方式,后者是异步通信方式。无论是同步或异步,这些通信方式都是必需的。 Service Broker是从Microsoft SQL Server 2005系统开始增加的新技术,是数据库引擎的重要组成部分,它提供了异步通信方式,可以缩短交互式时间,增加应用程序的总吞吐量。 本章讲述有关Service Broker的工作原理和使用方式。 * 第*页 本章要点 同步通信方式和异步通信方式的特点 Service Broker体系架构的特点 定义Service Broker对象 操纵Service Broker对象 启用Service Broker系统 开发Service Broker应用程序 * 第*页 本章内容 16.1 概述 16.2 Service Broker体系架构 16.3 开发Service Broker应用程序的工具 16.4 Service Broker应用程序示例 16.5 查看Service Broker信息 16.6 本章小结 16.1 概述 在数据库系统中,同步通信方式和异步通信方式都很重要,都是满足用户需求的重要方式。不同的场景下需要不同的通信方式。 在使用数据库的场景中,大多数情况下采用同步通信方式。例如,发出一个指令,希望立即可以得到系统的响应,这时需要同步通信方式。同步通信方式虽然可以满足用户的即刻需要,但是它也存在一系列问题。同步通信方式经常造成系统忙闲不均,在系统通信高峰期,从发出指令到收到回应的效率往往很低,使得应用程序的吞吐量下降。 * 第*页 异步通信机制 如果采用异步通信机制,可以有效地解决通信效率低下的问题。发信人发出指令,并不希望立即得到系统的响应,只要系统能够保证收到指令即可。在这种通信机制下,系统可以将响应安排在闲暇时进行处理,收信人也可以根据自己的工作时间灵活地查看信件。但是,需要注意的是,异步通信机制不能有效地解决紧急发生并且需要立即回应的用户通信需求,而这正是同步通信方式解决的问题。 * 第*页 16.2 Service Broker体系架构 Service Broker是一种与Microsoft SQL Server引擎紧密集成的应用程序架构,其目标是创建异步通信程序。它支持跨越多个Microsoft SQL Server系统的消息发送。在通信过程中,Service Broker将大量消息分解成多个小的信息块,然后将它们通过网络传输,在另外一端重新组合起来。Service Broker体系架构描述了Service Broker的组成部分和这些组成部分之间的关系,其体系架构示意图如图16-1所示。 * 第*页 Service Broker体系架构示意图 * 第*页 16.3 开发Service Broker应用程序的工具 下面,从3个不同的方面研究如何开发Service Broker应用程序。这3个方面分别是如何定义Service Broker对象,如何操纵Service Broker对象和如何启用Service Broker。 在Microsoft SQL Server 2008系统中可以使用Transact-SQL语言中的DDL语句定义Service Broker对象,这些语句和特点如表16-1所示。 * 第*页 启用ElecTravelCom数据库的Service Broker * 第*页 16.4 Service Broker应用程序示例 本节介绍一个简单的Service Broker应用程序示例。首先,讲述如何创建所需的Service Broker对象,然后分析如何使用这些对象。该示例是一个简单的异步通信系统,它将一个文本消息放置到输入队列中,然后再从队列中读取消息。 * 第*页 创建所需Service Broker对象的脚本 * 第*页 检索空队列 * 第*页 向队列中添加消息 * 第*页 查看ReceiverQueueSample队列的消息 * 第*页 查看ReceiverQueueSample队列的消息内容 * 第*页 队列中获取消息的脚本命令 * 第*页 16.5 查看Service Broker信息 Microsoft SQL Server 2008系统提供了多个系统视图,可以用来检索有关Service Broker对象及其当前状态的信息,这些系统视图如表16-3所示。 * 第*页 16.6 本章小结 本章介绍了Service Broke
文档评论(0)