偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

百寶箱教你使用ADO.NET FAQ連接池

開發(fā) 后端
這里就何時(shí)創(chuàng)建ADO.NET FAQ連接池、何時(shí)關(guān)閉連接池、當(dāng)連接池中的連接都已經(jīng)用完,而有新的連接請(qǐng)求到來時(shí)會(huì)發(fā)生什么等等介紹。

#T#ADO.NET有很多值得學(xué)習(xí)的地方,這里我們主要介紹ADO.NET FAQ連接池,包括介紹連接池的解決方法等方面。問題,一種CS架構(gòu)的程序,直接把SQL Server作為服務(wù)端,每個(gè)客戶端直接連接數(shù)據(jù)庫操作,如果客戶端打開的數(shù)量過多時(shí)SQL Server的連接數(shù)將會(huì)特別高,數(shù)據(jù)庫端形成性能瓶頸,這種情況下怎么辦?想了想,造成這種情況的原因是ADO.NET的內(nèi)部機(jī)制造成的。 ADO.NET中為了提高性能,所以使用了連接池,這樣每個(gè)請(qǐng)求就不必都創(chuàng)建一個(gè)連接,然后認(rèn)證,然后執(zhí)行SQL,而是從連接池中直接取出連接執(zhí)行 SQL,執(zhí)行完成后也并不是真正關(guān)閉連接,而是將該連接重新放回連接池中。如果有100個(gè)客戶端,每個(gè)客戶端在使用一段時(shí)間后連接池中保存了10個(gè)連接,那么在這種情況下,即使不在客戶端做任何操作,SQL Server上都有1000個(gè)連接,這樣不出性能問題才怪。

既然是連接池的問題,針對(duì)該問題的2個(gè)解決辦法:

1.關(guān)閉ADO.NET的連接池,每次執(zhí)行SQL時(shí)都是新建一個(gè)連接執(zhí)行,然后關(guān)閉。這樣做將使數(shù)據(jù)查詢有所減慢(每次都建立連接,每次都認(rèn)證,當(dāng)然會(huì)慢了),不過這個(gè)慢是毫秒級(jí)的,一般感覺不到的,但是如果一個(gè)操作就涉及到幾百個(gè)SQL語句的情況可能會(huì)明細(xì)感覺到減慢。修改方法特別簡(jiǎn)單,都不用修改代碼,在數(shù)據(jù)庫鏈接字符串中加入Pooling=False;即可。

2.修改架構(gòu),這種CS架構(gòu)除了性能問題外還會(huì)出現(xiàn)其他的比如安全上的問題。可以將直接連數(shù)據(jù)庫的方法改成連接服務(wù),這其中可以使用Remoting、Web服務(wù)等,當(dāng)然現(xiàn)在可以統(tǒng)一用WCF了。這樣做就只有服務(wù)程序去連接數(shù)據(jù)庫,而客戶端只連接服務(wù)程序,這樣就不會(huì)出現(xiàn)連接池造成的瓶頸。不過這樣做代碼修改量很大,若真要改還是很痛苦的。


ADO.NET FAQ連接池

1. 何時(shí)創(chuàng)建ADO.NET FAQ連接池?

當(dāng)***個(gè)連接請(qǐng)求到來時(shí)創(chuàng)建連接池;連接池的建立由數(shù)據(jù)庫連接的連接字符創(chuàng)來決定。每一個(gè)連接池都與一個(gè)不同的連接字符串相關(guān)。當(dāng)一個(gè)新的連接請(qǐng)求到來時(shí)如果連接字符串和連接池使用的字符串相同,就從連接池取出一個(gè)連接;如果不相同,就新建一個(gè)連接池。

2. 何時(shí)關(guān)閉連接池?

當(dāng)連接池中的所有連接都已經(jīng)關(guān)閉時(shí)關(guān)閉連接池。

3. 當(dāng)連接池中的連接都已經(jīng)用完,而有新的連接請(qǐng)求到來時(shí)會(huì)發(fā)生什么?

當(dāng)連接池已經(jīng)達(dá)到它的***連接數(shù)目時(shí),有新的連接請(qǐng)求到來時(shí),新的連接請(qǐng)求將放置到連接隊(duì)列中。當(dāng)有連接釋放給連接池時(shí),連接池將新釋放的連接分配給在隊(duì)列中排隊(duì)的連接請(qǐng)求。你可以調(diào)用close和dispose將連接歸還給連接池。

4. 我應(yīng)該如何允許連接池?

對(duì)于.NET應(yīng)用程序而言,默認(rèn)為允許連接池。(這意味著你可以不必為這件事情做任何的事情)當(dāng)然,如果你可以在SQLConnection對(duì)象的連接字符串中加進(jìn)Pooling=true;確保你的應(yīng)用程序允許連接池的使用。

5. 我應(yīng)該如何禁止連接池?

ADO.NET默認(rèn)為允許數(shù)據(jù)庫連接池,如果你希望禁止連接池,可以使用如下的方式:

1) 使用SQLConnection對(duì)象時(shí),往連接字符串加入如下內(nèi)容:Pooling=False;

2) 使用OLEDBConnection對(duì)象時(shí),往連接字符串加入如下內(nèi)容:OLE DB Services=-4;

責(zé)任編輯:田樹 來源: 博客
相關(guān)推薦

2009-11-03 16:17:39

ADO.NET Ent

2009-11-12 14:18:19

ADO.NET分頁

2009-10-28 09:48:31

VB.NET XmlR

2009-11-11 14:04:14

ADO.NET連接池

2009-11-05 11:12:21

WCF自宿主

2009-10-27 13:14:35

VB.NET窗體應(yīng)用

2009-11-03 15:58:22

2009-12-23 14:53:28

ADO.NET連接池

2015-09-22 15:24:27

SDNDocker

2015-09-22 16:11:41

SDNDocker

2009-10-28 14:51:33

VB.NET設(shè)計(jì)制作窗

2009-11-13 13:11:37

ADO.NET連接池

2009-12-23 09:01:15

ADO.NET連接池

2009-11-03 16:51:04

ADO.NET連接池觀

2009-12-23 09:14:52

ADO.NET連接池

2009-12-30 16:22:58

ADO.NET連接池

2009-10-28 13:54:38

linux安裝顯卡驅(qū)動(dòng)

2009-10-27 15:42:04

VB.NET文件對(duì)象

2009-10-28 12:05:32

linux監(jiān)控技術(shù)

2011-04-13 09:40:27

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)