日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

SQL Server 2005基于消息的應用程序介紹_Mssql數據庫教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:逐行掃描 為你講解幾個基本SQLPLUS命令
本文章幫你充分認識SQLPLUS命令。 remark:告訴SQLPLUS接下來的文字是注釋,不是命令。 set haedsep:標題分隔符標識一個告訴SQLPLUS將一個標題分為兩行或更多行的字符。 ttitle:設置報

基于消息的應用程序并不是一個新概念,一直以來,從頭編寫這樣的應用程序都相當困難。我將在一系列三篇文章中討論一個建立異步消息應用程序的新平臺,本文為第一篇,我將在其中說明基于消息的應用程序這一概念,以及一個建立包含在SQL Server 2005中的這些應用程序的新型基礎程序。

基于消息的應用程序介紹

處理消息的應用程序是大體上會成功的應用程序。實際上,大多數大型應用程序都應用了某種類型的消息處理。這種處理可能相當簡單,例如,把一個文件放在網絡共享中,以便另一個應用程序能夠處理這個文件;之后,你就可以檢查網絡共享,看文件是否得到處理。

雖然這不是一個非常復雜的消息應用程序,但其背后的概念是一樣的:提交一條消息,應用程序執(zhí)行其工作。然后,再檢查看是否收到確認消息已得到處理的信息。這種處理方法擁有許多獨特的優(yōu)點:

延期處理:有時候,要想在給定的時間處理某個任務的所有工作是不切實際的。許多時候,當你的應用程序能夠處理的任務達到一個瓶頸點時,最好把剩下的任務交給另一個應用程序進行處理。

在線購買機票就屬于這種情況。當你到一個網站購買機票時,你輸入諸如出發(fā)城市、到達城市、旅行日期和隨行乘客人數之類的信息。在你輸入信用卡信息后,你將收到一封確認電子郵件。在后臺,某種類型的消息已被提交給另一個執(zhí)行請求的服務進行處理。如果不能滿足訂票請求,你收到的電子郵件就會說明這一點。
這種處理的好處在于它減輕了后臺數據庫系統堵塞的壓力。而且,如果要求顧客長時間等待網站的確認,大多數顧客都會感到非常不滿。另外,如果所有處理任務都在一個單功能事務中完成,就可能發(fā)生嚴重的死鎖情況,從而負面影響在網站上購買機票的顧客的購買體驗。

分布式處理:一般來說,最好盡可能迅速地處理一項任務。但是,有時候很難確定有多少待處理的任務、完成這些任務需要耗用多少資源。下面我們看一個這種處理的實例。

超市中有許多結賬通道。通道的數量一般根據超市的資源來配備。有時,例如星期六下午,結賬通道變得十分擁擠,顧客必須排隊等候。只要超市的資源沒有耗盡,超市就能分配更多收銀員給顧客結賬。這樣既可加快結賬速度,又不至于影響超市的總體運作。
同樣的道理,消息應用程序也以相似的方式運作。如果你的應用程序充滿了待處理的請求,通常應該增加另外一條處理隊列來緩解系統的總體處理壓力。
微軟消息隊列

現在你可能已經體會到基于消息的應用程序帶來的價值,你也許想知道為什么你沒有經常聽說這種應用程序。主要的原因在于,開發(fā)這種應用程序是一個非常困難的任務。如果你計劃編寫自己的基于消息的應用程序,你要用大部分時間來開發(fā)處理消息的基礎架構。

好消息是,你不再需要開發(fā)自己的消息基礎架構。微軟消息隊列(MSMQ)提供一個開發(fā)這類應用程序的框架。它使得應用程序可以在不同種類的網絡間進行通信,并且需要保證消息傳送(guaranteed message delivery)、路由和可配置安全。MSMQ應用程序一般在以Visual Basic、C#或C 編寫的應用程序中開發(fā),不過也可以用其它程序語言編寫。這些應用程序在處理通常需要幾步完成的任務時表現優(yōu)異。這時,一個任務的每個步驟需要邏輯到達任務的下一個步驟,如一個業(yè)務工作流應用程序。

數據庫——不再只是用于存儲數據

過去20年來,我們對關系數據庫系統的依賴程度顯著增加。最初,存儲數據并對數據進行某種處理,是建立商業(yè)關系數據庫系統的主要目的。隨著關系數據庫系統的發(fā)展,其功能和復雜性的變化,它的主要用途已由單一數據存儲轉變?yōu)楦又髁鞯纳虡I(yè)智能目的、更加復雜的ETL處理、數據報告、數據通知;在SQL Server 2005中,它甚至已具備編寫在數據庫引擎中執(zhí)行的.NET CLR語言代碼的能力。因此,完全可以肯定地說,數據庫引擎已不再僅用于數據存儲。

Service Broker

微軟認為,允許你在數據庫內建立基于消息的應用程序,這樣才有意義。Service Broker是SQL Server 2005中新添加的基礎程序,主要用于在數據庫引擎內建立基于消息的應用程序。這些應用程序在數據庫引擎內使用新的TSQL結構而開發(fā)。

Service Broker應用程序以松散連接的應用程序而開發(fā),它具有高度可擴展性,并提供其它消息平臺所不具備的功能,如消息組協調和鎖定。這些應用程序充分支持事務,并能夠跨越數據庫實例和服務器。

分享:防范sql注入式攻擊js版本
SQL注入式攻擊是利用是指利用設計上的漏洞,在目標服務器上運行Sql命令以及進行其他方式的攻擊 。 動態(tài)生成Sql命令時沒有對用戶輸入的數據進行驗證是Sql注入攻擊得逞的主要原因。 比如:

來源:模板無憂//所屬分類:Mssql數據庫教程/更新時間:2008-08-22
相關Mssql數據庫教程