最新文章專題視頻專題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

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

來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:44:42
文檔

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

.NET 數(shù)據(jù)庫(kù)連接池:則您需要負(fù)責(zé)打開 SqlConnection 對(duì)象,而且,更重要的是,在查詢結(jié)束時(shí)關(guān)閉該對(duì)象。如果您忘記了進(jìn)行關(guān)閉,孤立連接會(huì)迅速地積累起來(lái)。監(jiān)視連接數(shù) 為了對(duì)孤立連接和發(fā)生溢出的連接池進(jìn)行測(cè)試,我編寫了一個(gè) Web 窗體的示例應(yīng)用程序。此應(yīng)用程序使用的方法與
推薦度:
導(dǎo)讀.NET 數(shù)據(jù)庫(kù)連接池:則您需要負(fù)責(zé)打開 SqlConnection 對(duì)象,而且,更重要的是,在查詢結(jié)束時(shí)關(guān)閉該對(duì)象。如果您忘記了進(jìn)行關(guān)閉,孤立連接會(huì)迅速地積累起來(lái)。監(jiān)視連接數(shù) 為了對(duì)孤立連接和發(fā)生溢出的連接池進(jìn)行測(cè)試,我編寫了一個(gè) Web 窗體的示例應(yīng)用程序。此應(yīng)用程序使用的方法與

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

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

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

.NET 數(shù)據(jù)庫(kù)連接池:則您需要負(fù)責(zé)打開 SqlConnection 對(duì)象,而且,更重要的是,在查詢結(jié)束時(shí)關(guān)閉該對(duì)象。如果您忘記了進(jìn)行關(guān)閉,孤立連接會(huì)迅速地積累起來(lái)。監(jiān)視連接數(shù) 為了對(duì)孤立連接和發(fā)生溢出的連接池進(jìn)行測(cè)試,我編寫了一個(gè) Web 窗體的示例應(yīng)用程序。此應(yīng)用程序使用的方法與
推薦度:
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top