欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

.NET 數(shù)據(jù)庫連接池

 更新時間:2008年12月25日 00:13:35   作者:  
如果您通過使用另一個 Execute 方法(例如,ExecuteScalar、ExecuteNonQuery 和 ExecuteXMLReader)執(zhí)行查詢
則您需要負責打開 SqlConnection 對象,而且,更重要的是,在查詢結束時關閉該對象。如果您忘記了進行關閉,孤立連接會迅速地積累起來。
監(jiān)視連接數(shù)
為了對孤立連接和發(fā)生溢出的連接池進行測試,我編寫了一個 Web 窗體的示例應用程序。此應用程序使用的方法與您通常用于從查詢返回數(shù)據(jù)的方法相同。(您可以在 http://www.sqlmag.com 上下載此代碼的 WinForms 版本。)
我使用了清單 1 中的代碼來打開和關閉到 Web 窗體應用程序的連接。標注 A 中的例程針對 110 個新的 SqlConnection 對象創(chuàng)建、打開和執(zhí)行查詢 — 比默認的池大小多 10 個連接。您必須在離開該例程之前關閉和放棄所有這些連接。如果不這樣做,SqlConnection 對象將連同關聯(lián)的池連接一起被孤立。ADO.NET 池機制 (aka the pooler) 關閉數(shù)據(jù)庫連接,但不關閉池連接。我將連接池大小設置為 10,以便使該程序更快地失敗 — 如果該程序會失敗的話。通常,10 個連接對于一個運行速度象這個查詢一樣快的查詢來說已經(jīng)足夠了。許多開發(fā)人員運行著忙碌的 Web 站點,這些 Web 站點使用不到五個連接來處理每天的幾十萬次點擊。
標注 A 中的例程創(chuàng)建 SqlConnection 對象和 SqlCommand 對象,設置 CommandText,并打開連接。然后,標注 B 中的代碼確定執(zhí)行 DataReader 時是否使用 CommandBehavior.CloseConnection,這取決于用戶在 Web 窗體上選擇了哪些 CheckBox 控件。
在標注 C 的代碼中,我指定是否將 DataReader 行集綁定到 DataGrid,或者是否在整個行集中進行循環(huán)。標注 C 的代碼測試當您到達通過 DataReader 從數(shù)據(jù)提供程序傳遞回來的行集的末尾時會發(fā)生什么事情。
現(xiàn)在,我使用標注 D 中的代碼來指定是手工關閉連接還是讓某個其他操作(例如,數(shù)據(jù)綁定)來完成這項工作。坦白地說,以手工方式關閉連接通常是最安全的,因此,您可以肯定連接不會被孤立。
如果代碼成功地運行到這一步,說明我已經(jīng)成功地打開和關閉了 110 個連接。不過,如果出了問題,標注 E 的代碼中的異常處理程序會將異常(通常是 Timeout)作為 InvalidOperationException 捕獲,該異常是連接池已滿時 ADO.NET 的響應方式。
表 1 匯總了各個選項使例程成功運行或失敗的方式。請注意,如果您不設置 CommandBehavior.CloseConnection 選項,您的操作最終會失敗 — 即使在使用綁定控件的情況下也是如此。即使您使用該選項,但如果您沒有使用復雜的綁定控件,或者沒有手工關閉 SqlDataAdapter 或 SqlConnection,該進程仍然會失敗。
當我結束了這些示例應用程序的運行后,我已經(jīng)生成了 1000 多個以上的池連接 — 所有連接均處于孤立狀態(tài)。雖然“SQL Server 用戶連接”計數(shù)為 0,但留下大約 40 個連接池。在我重新引導系統(tǒng)之前,孤立的池不會消失。
我用于此測試的示例應用程序包括使用 DataAdapter 來返回行的例程。除非您手工管理連接,否則,DataAdapter 將正確地打開和關閉 SqlConnection 對象,因此,您不太可能遇到孤立的池連接。不過,如果您的應用程序同時使用 DataReader 和 DataAdapter,您可能會發(fā)現(xiàn),如果某個連接與一個未關閉的 DataReader 相關聯(lián),則 DataAdapter 無法針對該連接運行查詢。
確定連接池何時達到最大連接數(shù)
正如我在 "Swimming in the .NET Connection Pool" 一文中討論的那樣,當連接池達到您通過 "Max Pool Size ConnectionString" 選項指定的最大連接數(shù)時,ADO.NET 將阻止任何隨后打開額外連接的嘗試。如果某個連接在您在 "ConnectionTimeout 選項中指定的時間之前變?yōu)榭捎?,。NET 數(shù)據(jù)提供程序將向您的應用程序傳遞一個指向該連接的指針,以便將控件返回給應用程序。不過,如果沒有及時釋放任何連接,連接請求將引發(fā) InvalidOperationException 異常。
現(xiàn)在您必須決定要采取的措施,我不建議您告訴用戶您已經(jīng)用完了所有連接。有些應用程序會通知用戶系統(tǒng)正忙于幫助其他客戶,并建議用戶稍后進行訪問。其他應用程序則播放一段動畫,通知用戶系統(tǒng)尚未死鎖,而是正在忙于處理他們的請求。同時,您的代碼重新嘗試操作。在所有情況下,您應該記錄這些故障,以便幫助診斷問題的癥結所在,并記錄您已經(jīng)耗盡了資源。

相關文章

  • .NET中 關于臟讀 不可重復讀與幻讀的代碼示例

    .NET中 關于臟讀 不可重復讀與幻讀的代碼示例

    本篇文章小編將為大家介紹,.NET中 關于臟讀 不可重復讀與幻讀的代碼示例,有需要的朋友可以參考一下
    2013-04-04
  • js與ASP.NET 中文亂碼問題

    js與ASP.NET 中文亂碼問題

    本文摘自一位哥們的QQ空間里,自認為方案比較可行,也確實解決了開發(fā)中的這一類問題,非原創(chuàng),寫在此是為以后自己能方便的找到,也希望對其他的朋友有幫助。
    2009-10-10
  • asp.net開發(fā)中常見公共捕獲異常方式總結(附源碼)

    asp.net開發(fā)中常見公共捕獲異常方式總結(附源碼)

    這篇文章主要介紹了asp.net開發(fā)中常見公共捕獲異常方式總結,結合實例形式較為詳細的分析了asp.net捕獲異常的相關技巧,并提供了完整的實例代碼供讀者下載參考,需要的朋友可以參考下
    2015-11-11
  • asp.net操作過程中常見錯誤的解決方法

    asp.net操作過程中常見錯誤的解決方法

    這篇文章主要介紹了asp.net操作過程中常見錯誤的解決方法,主要有IIS無法識別ASP.NET、 SQL Server不允許進行遠程連接可能會導致此失敗等問題,感興趣的小伙伴們可以參考一下
    2015-10-10
  • .NetCore利用BlockingCollection實現(xiàn)簡易消息隊列

    .NetCore利用BlockingCollection實現(xiàn)簡易消息隊列

    這篇文章主要介紹了.NetCore利用BlockingCollection實現(xiàn)簡易消息隊列,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • .NET?Core支持Cookie和JWT混合認證、授權的方法

    .NET?Core支持Cookie和JWT混合認證、授權的方法

    這篇文章主要介紹了.NET?Core如何支持Cookie和JWT混合認證、授權,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-01-01
  • asp.net圖片文件的上傳與刪除方法

    asp.net圖片文件的上傳與刪除方法

    這篇文章主要介紹了asp.net圖片文件的上傳與刪除方法,簡單分析了jpg格式圖片的上傳與文件刪除技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2016-05-05
  • Asp.net 自帶報表的使用詳解

    Asp.net 自帶報表的使用詳解

    最近公司的功能需要使用報表,用的是微軟自帶的報表,談一談我們的做法,希望可以給想學習的人一些指導
    2013-10-10
  • MVC使用Spring.Net應用IOC(依賴倒置)學習筆記3

    MVC使用Spring.Net應用IOC(依賴倒置)學習筆記3

    這篇文章主要為大家詳細介紹了MVC使用Spring.Net應用IOC(依賴倒置),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • .NET中的異步編程-EAP/APM使用方法及案例介紹

    .NET中的異步編程-EAP/APM使用方法及案例介紹

    從.NET 4.5開始,支持的三種異步編程模式:基于事件的異步編程設計模式;異步編程模型;基于任務的編程模型接下來先總結一下舊有的2種模式:EAP、APM,感興趣的朋友可以了解下
    2013-01-01

最新評論