设为首页 收藏本站
查看: 957|回复: 0

[经验分享] SQL Server 2008中Service Broker基础应用(下 )

[复制链接]

尚未签到

发表于 2016-11-5 01:22:08 | 显示全部楼层 |阅读模式
  SQL Server 2008中SQL应用系列--目录索引
  
  导读:在上篇《SQL Server 2008中Service Broker基础应用(上)》中,简要介绍了Service Broker的一般步骤,本文继续介绍Service Broker的设置会话优先级,存储过程中实现。
  一、Service Broker的设置会话优先级
  自SQL Server 2008起,对非常活跃的Service Broker应用程序,提供了设置优先级的命令CREATE BROKER PRIORITY(http://msdn.microsoft.com/en-us/library/bb934170.aspx)。通过该命令,可以设置从1至10共10个等级的颗粒度来调试会话的优先级,默认为5。在此之前,你必须得首先打开HONOR_BROKER_PRIORITY开关。
  -- 设置会话优先级--启用会话优先级选项ALTER DATABASE BookStoreSET HONOR_BROKER_PRIORITY ON--启用会话优先级选项ALTER DATABASE BOOKDistributionSET HONOR_BROKER_PRIORITY ON--查看设置结果SELECT name, is_honor_broker_priority_onFROM sys.databasesWHERE name IN ('BookStore', 'BookDistribution')/*name is_honor_broker_priority_onBookStore 1BookDistribution 1*/USE BookStoreGOCREATE BROKER PRIORITY Conv_Priority_BookOrderContract_BookOrderServiceFOR CONVERSATIONSET (CONTRACT_NAME = [//SackConsulting/BookOrderContract],--特定的契约LOCAL_SERVICE_NAME = [//SackConsulting/BookOrderService],--本地服务REMOTE_SERVICE_NAME = ANY,--远程服务为ANY,即Service Broker端点的任何相关服务PRIORITY_LEVEL = 10)--设置优先级为10
  通过sys.conversation_priorities目录视图,查询优先级
  SELECT name, priority, service_contract_id,local_service_id,remote_service_nameFROM sys.conversation_priorities cp/*name priority service_contract_id local_service_id remote_service_nameConv_Priority_BookOrderContract_BookOrderService 10 65536 65536 NULL*/
  如果你希望包含服务和契约名称,可以将服务和从sys.conversation_priorities(http://msdn.microsoft.com/zh-cn/library/bb895280%28v=sql.100%29.aspx)返回的契约ID与sys.service_contracts(http://msdn.microsoft.com/en-us/library/ms184378.aspx),sys.services(http://msdn.microsoft.com/en-us/library/ms174429.aspx)目录视图关联起来。
  USE BookDistributionGO--创建目标服务的优先级,与发起方的优先级保持一致,--以使会话的优先级设置覆盖整个会话的生命周期CREATE BROKER PRIORITY Conv_Priority_BookOrderContract_BookDistributionServiceFOR CONVERSATIONSET (CONTRACT_NAME = [//SackConsulting/BookOrderContract],LOCAL_SERVICE_NAME = [//SackConsulting/BookDistributionService],REMOTE_SERVICE_NAME = ANY,PRIORITY_LEVEL = 10)USE BookStoreGOALTER BROKER PRIORITY Conv_Priority_BookOrderContract_BookOrderServiceFOR CONVERSATIONSET (REMOTE_SERVICE_NAME = '//SackConsulting/BookDistributionService')--修改远程服务名称ALTER BROKER PRIORITY Conv_Priority_BookOrderContract_BookOrderServiceFOR CONVERSATIONSET (PRIORITY_LEVEL = 9)--设置优先级--删除优先级设置DROP BROKER PRIORITY Conv_Priority_BookOrderContract_BookOrderService
  
  二、Service Broker的存储过程实现
  在上文中,我们使用的临时T-SQL来演示Service broker的步骤,事实上, 我们完全可以通过存储过程或外部应用程序自动激活并处理队列中的消息。使用Create Queue(http://msdn.microsoft.com/en-us/library/ms190495.aspx)和Alter Queue(http://msdn.microsoft.com/en-us/library/ms189529.aspx)选项,也可以指定可以激活并处理在同一队列中传入的消息的、同时执行的相同服务程序的数量。
  继续上文的示例:
  -- Creating the Bookstore Stored ProcedureUSE BookDistributionGOCREATE PROCEDURE dbo.usp_SB_ReceiveOrdersASDECLARE @Conv_Handler uniqueidentifierDECLARE @Conv_Group uniqueidentifierDECLARE @OrderMsg xmlDECLARE @TextResponseMsg varchar(8000)DECLARE @ResponseMsg xmlDECLARE @Message_Type_Name nvarchar(256);DECLARE @OrderID int;-- XACT_ABORT automatically rolls back the transaction when a runtime error occursSET XACT_ABORT ONBEGIN TRAN;RECEIVE TOP(1) @OrderMsg = message_body,@Conv_Handler = conversation_handle,@Conv_Group = conversation_group_id,@Message_Type_Name = message_type_nameFROM dbo.BookDistributionQueue;IF @Message_Type_Name = '//SackConsulting/SendBookOrder'BEGININSERT dbo.BookOrderReceived(conversation_handle, conversation_group_id, message_body)VALUES(@Conv_Handler,@Conv_Group, @OrderMsg )SELECT @OrderID = @OrderMsg.value('(/order/@id)[1]', 'int' )SELECT @TextResponseMsg ='<orderreceived id= "' +CAST(@OrderID as varchar(10)) +'"/>';SELECT @ResponseMsg = CAST(@TextResponseMsg as xml);SEND ON CONVERSATION @Conv_HandlerMESSAGE TYPE [//SackConsulting/BookOrderReceived](@ResponseMsg );ENDIF @Message_Type_Name = 'http://schemas.microsoft.com/SQL/ServiceBroker/EndDialog'BEGINEND CONVERSATION @Conv_Handler;ENDCOMMIT TRANGO
  解析:该存储过程包含处理//SackConsulting/SendBookOrder和http://schemas.microsoft.com/SQL/ServiceBroker/EndDialog消息类型的逻辑。如果发送发后者,特定会话的句柄的特定会话会结束。如果接收到图书订单消息类型,它的消息将插入到表中,并且返回订单确认信息。
  可以使用Alter Queue命令修改既有的队列。这个命令使用与Create Queue相同的选项,它允许改变队列的状态与保持期、待激活的存储过程、队列读取存储过程实例的最大数量以及过程的安全模式契约。
  Alter Queue包括一个额外的参数Drop,它用来删除队列的所有存储过程激活设置。
  使用Alter Queue命令将存储过程绑定到既有的队列:
  ----使用Alter Queue命令将存储过程绑定到既有的队列ALTER QUEUE dbo.BookDistributionQueueWITH ACTIVATION (STATUS = ON,PROCEDURE_NAME = dbo.usp_SB_ReceiveOrders,MAX_QUEUE_READERS = 2,--独立处理队列中不同消息的同一存储过程同时执行的最大数量EXECUTE AS SELF)--即存储过程将以与执行Alter Queue命令的主体的相同的权限来执行
  为了测试BookStore数据库的新服务程序,开始一个会话并设置新顺序:
  Use BookStoreGODECLARE @Conv_Handler uniqueidentifierDECLARE @OrderMsg xml;BEGIN DIALOG CONVERSATION @conv_handlerFROM SERVICE [//SackConsulting/BookOrderService]TO SERVICE '//SackConsulting/BookDistributionService'ON CONTRACT [//SackConsulting/BookOrderContract];SET @OrderMsg ='<order id="3490" customer="29" orderdate="7/22/2008"><LineItem ItemNumber="1" ISBN="1-59059-592-0" Quantity="2" /></order>';SEND ON CONVERSATION @Conv_HandlerMESSAGE TYPE [//SackConsulting/SendBookOrder](@OrderMsg);
  当队列Status=ON并且队列中到到达新消息时,执行存储过程来处理传入的消息。可以使用存储过程或外部程序,但使用存储过程的好处是,它们提供了处理消息、自动执行所有需要的响应和相关业务任务的简单的封装好的组件。
  如果在目标队列上有存储过程被执行,并且激活新的接收到的消息,那么应该已经有订单确认消息返回到dbo.BookStoreQueue:
  SELECT conversation_handle, CAST(message_body as xml) messageFROM dbo.BookStoreQueue/*conversation_handle messageA7B7FA73-5B5F-E011-8B4E-001C23FA56DD <orderreceived id="3439" />*/
  
  
  小结:本文主要介绍Service Broker的设置会话优先级,存储过程中实现。下文将介绍Service broker的远程实现。
  
  
邀月注:本文版权由邀月和CSDN共同所有,转载请注明出处。
助人等于自助! 3w@live.cn

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-295726-1-1.html 上篇帖子: 二十五.Sql server中join的使用方法 下篇帖子: SQL Server 字符串处理函数大全(例子)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表