女人被狂躁到高潮视频免费无遮挡,内射人妻骚骚骚,免费人成小说在线观看网站,九九影院午夜理论片少妇,免费av永久免费网址

當(dāng)前位置:首頁(yè) > > 充電吧
[導(dǎo)讀]摘要今天我要講的是數(shù)據(jù)庫(kù)連接池。說(shuō)實(shí)話,我表示鴨梨很大。因?yàn)橄啾绕渌鹿?jié)來(lái)說(shuō),連接池相對(duì)來(lái)說(shuō)難理解一點(diǎn)。我要用最通俗的語(yǔ)句給大家講明白,講透徹卻也不是一件很容易的事。但是,連接池又是非常重要的知識(shí)點(diǎn),

摘要

今天我要講的是數(shù)據(jù)庫(kù)連接池。說(shuō)實(shí)話,我表示鴨梨很大。因?yàn)橄啾绕渌鹿?jié)來(lái)說(shuō),連接池相對(duì)來(lái)說(shuō)難理解一點(diǎn)。我要用最通俗的語(yǔ)句給大家講明白,講透徹卻也不是一件很容易的事。但是,連接池又是非常重要的知識(shí)點(diǎn),特別是在部署多用戶程序時(shí),顯得尤為重要。所以,我不但要講,而且要講的透徹。通過(guò)本文,你將理解連接池的基本原理已經(jīng)如何利用連接池來(lái)提高應(yīng)用程序的性能。


目錄 什么是連接池?連接池的工作原理說(shuō)說(shuō)連接池的幾個(gè)非常重要屬性連接池異常與處理方法監(jiān)視連接狀態(tài)的方法高效使用連接池的基本原則


1. 什么是連接池?

????? 在上篇文章《你必須知道的ADO.NET(四) 品味Connection對(duì)象》中,我已經(jīng)強(qiáng)調(diào)過(guò),建立一個(gè)數(shù)據(jù)庫(kù)連接是一件非常耗時(shí)(消耗時(shí)間)耗力(消耗資源)的事情。之所以會(huì)這樣,是因?yàn)檫B接到數(shù)據(jù)庫(kù)服務(wù)器需要經(jīng)歷幾個(gè)漫長(zhǎng)的過(guò)程:建立物理通道(例如套接字或命名管道),與服務(wù)器進(jìn)行初次握手,分析連接字符串信息,由服務(wù)器對(duì)連接進(jìn)行身份驗(yàn)證,運(yùn)行檢查以便在當(dāng)前事務(wù)中登記等等。我們先不管為什么會(huì)有這樣的機(jī)制,存在總是有它的道理。既然新建一條連接如此痛苦,那么為什么不重復(fù)利用已有的連接呢?

????? 實(shí)際上,ADO.NET已經(jīng)為我們提供了名為連接池的優(yōu)化方法。連接池就是這樣一個(gè)容器:它存放了一定數(shù)量的與數(shù)據(jù)庫(kù)服務(wù)器的物理連接。因此,當(dāng)我們需要連接數(shù)據(jù)庫(kù)服務(wù)器的時(shí)候,只需去池(容器)中取出一條空閑的連接,而不是新建一條連接。這樣的話,我們就可以大大減少連接數(shù)據(jù)庫(kù)的開(kāi)銷,從而提高了應(yīng)用程序的性能。

?PS:本來(lái)做了2張圖片來(lái)描述連接池的,無(wú)奈公司裝有監(jiān)控軟件,不能上傳,所以只能等下次有時(shí)間上傳了。

?

2. 連接池的工作原理 2.1 創(chuàng)建連接池

????? 需要說(shuō)明的是,連接池是具有類別區(qū)分的。也就是說(shuō),同一個(gè)時(shí)刻同一應(yīng)用程序域可以有多個(gè)不同類型的連接池。那么,連接池是如何標(biāo)識(shí)區(qū)分的?細(xì)致的講,是由進(jìn)程、應(yīng)用程序域、連接字符串以及windows標(biāo)識(shí)(在使用集成的安全性時(shí))共同組成簽名來(lái)標(biāo)識(shí)區(qū)分的。但對(duì)于同一應(yīng)用程序域來(lái)說(shuō),一般只由連接字符串來(lái)標(biāo)識(shí)區(qū)分。當(dāng)打開(kāi)一條連接時(shí),如果該條連接的類型簽名與現(xiàn)有的連接池類型不匹配,則創(chuàng)建一個(gè)新的連接池。反之,則不創(chuàng)建新的連接池。

????? 一個(gè)典型的創(chuàng)建連接的實(shí)例:

//創(chuàng)建連接對(duì)象1
using?(SqlConnection?conn1?=

new?SqlConnection(??"DataSource=(local);Integrated?Security=SSPI;Initial?Catalog=Northwind"))????
{????????
????conn1.Open();???????
}


//創(chuàng)建連接對(duì)象2
using?(SqlConnection?conn2?=

new?SqlConnection(??"DataSource=(local);Integrated?Security=SSPI;Initial?Catalog=pubs"))???
{???????
????conn2.Open();??????
}


//創(chuàng)建連接對(duì)象3
using?(SqlConnection?conn3?=

new?SqlConnection(??"DataSource=(local);Integrated?Security=SSPI;Initial?Catalog=Northwind"))??
{????????
????conn3.Open();??????
}

上面實(shí)例中,我創(chuàng)建了三個(gè)SqlConnection對(duì)象,但是管理時(shí)只需要兩個(gè)連接池。細(xì)心的朋友,可能早已發(fā)現(xiàn)conn1與conn3的連接字符串相同,所以可以共享一個(gè)連接池,而conn2與conn1與conn3不同,所以需要?jiǎng)?chuàng)建新的連接池。

2.2 分配空閑連接

????? 當(dāng)用戶創(chuàng)建連接請(qǐng)求或者說(shuō)調(diào)用Connection對(duì)象的Open時(shí),連接池管理器首先需要根據(jù)連接請(qǐng)求的類型簽名找到匹配類型的連接池,然后盡力分配一條空閑連接。具體情況如下:

如果池中有空閑連接可用,返回該連接。如果池中連接都已用完,創(chuàng)建一個(gè)新連接添加到池中。如果池中連接已達(dá)到最大連接數(shù),請(qǐng)求進(jìn)入等待隊(duì)列直到有空閑連接可用。 2.3 移除無(wú)效連接?

????? 無(wú)效連接,即不能正確連接到數(shù)據(jù)庫(kù)服務(wù)器的連接。對(duì)于連接池來(lái)說(shuō),存儲(chǔ)的與數(shù)據(jù)庫(kù)服務(wù)器的連接的數(shù)量是有限的。因此,對(duì)于無(wú)效連接,如果如不及時(shí)移除,將會(huì)浪費(fèi)連接池的空間。其實(shí)你不用擔(dān)心,連接池管理器已經(jīng)很好的為我們處理了這些問(wèn)題。如果連接長(zhǎng)時(shí)間空閑,或檢測(cè)到與服務(wù)器的連接已斷開(kāi),連接池管理器會(huì)將該連接從池中移除。

2.4 回收使用完的連接

??????當(dāng)我們使用完一條連接時(shí),應(yīng)當(dāng)及時(shí)關(guān)閉或釋放連接,以便連接可以返回池中重復(fù)利用。我們可以通過(guò)Connection對(duì)象的Close或Dispose方法,也可以通過(guò)C#的using語(yǔ)句來(lái)關(guān)閉連接。

?

3. 說(shuō)說(shuō)幾個(gè)非常重要屬性

連接池的行為可以通過(guò)連接字符串來(lái)控制,主要包括四個(gè)重要的屬性:

Connection Timeout:連接請(qǐng)求等待超時(shí)時(shí)間。默認(rèn)為15秒,單位為秒。Max Pool Size:?連接池中最大連接數(shù)。默認(rèn)為100。Min Pool Size:?連接池中最小連接數(shù)。默認(rèn)為0。Pooling:?是否啟用連接池。ADO.NET默認(rèn)是啟用連接池的,因此,你需要手動(dòng)設(shè)置Pooling=false來(lái)禁用連接池。

還是看一個(gè)實(shí)例來(lái)理解連接池的屬性吧。代碼如下:

SqlConnectionStringBuilder?connStr?=?new?SqlConnectionStringBuilder();
????????????connStr.DataSource?=?@".SQLEXPRESS";
????????????connStr.InitialCatalog?=?"master";
????????????connStr.IntegratedSecurity?=?true;

????????????connStr.Pooling?=?true;?//開(kāi)啟連接池
?????????connStr.MinPoolSize?=?0;?//設(shè)置最小連接數(shù)為0
????????????connStr.MaxPoolSize?=?50;?//設(shè)置最大連接數(shù)為50?????????????
????????????connStr.ConnectTimeout?=?10;?//設(shè)置超時(shí)時(shí)間為10秒

using(?SqlConnection?conn?=?new?SqlConnection(connStr.ConnectionString))
????????????{
????????????????;//todo
????????????}

?

4. 連接池異常與處理方法

??????當(dāng)用戶打開(kāi)一個(gè)連接而沒(méi)有正確或者及時(shí)的關(guān)閉時(shí),經(jīng)常會(huì)引發(fā)“連接泄露”問(wèn)題。泄露的連接,會(huì)一直保持打開(kāi)狀態(tài),直到調(diào)用Dispose方法,垃圾回收器(GC)才關(guān)閉和釋放連接。與ADO不同,ADO.NET需要手動(dòng)的關(guān)閉使用完的連接。一個(gè)重要的誤區(qū)是:當(dāng)連接對(duì)象超出局部作用域范圍時(shí),就會(huì)關(guān)閉連接。實(shí)際上,當(dāng)超出作用域時(shí),釋放的只是連接對(duì)象而非連接資源。好吧,還是先看看一個(gè)實(shí)例吧。

using?System;
using?System.Collections.Generic;
using?System.Linq;
using?System.Text;
using?System.Data;
using?System.Data.SqlClient;

namespace?ConnectionPool
{
class?Program
????{
static?void?Main(string[]?args)
????????{
????????????SqlConnectionStringBuilder?connStr?=?new?SqlConnectionStringBuilder();
????????????connStr.DataSource?=?@".SQLEXPRESS";
????????????connStr.InitialCatalog?=?"master";
????????????connStr.IntegratedSecurity?=?true;

????????????connStr.MaxPoolSize?=?5;//設(shè)置最大連接池為5
????????????connStr.ConnectTimeout?=?1;//設(shè)置超時(shí)時(shí)間為1秒

??????????????SqlConnection?conn?=?null;
for?(int?i?=?1;?i?<=?100;?++i)
????????????{
????????????????conn?=?new?SqlConnection(connStr.ConnectionString);
try
????????????????{
????????????????????conn.Open();
????????????????????Console.WriteLine("Connection{0}?is?linked",i);
????????????????}
catch(Exception?ex)
????????????????{
????????????????????Console.WriteLine("n異常信息:n{0}",ex.Message);
break;
????????????????}
????????????}

????????????Console.Read();

????????}
????}
}

為了使結(jié)果更明顯,我特地將最大連接數(shù)設(shè)置為5,超時(shí)時(shí)間為1秒。運(yùn)行后,很快得到以下結(jié)果。

從上面的結(jié)果我們很明顯的知道,連接出現(xiàn)了異常。我們已經(jīng)知道連接池的最大連接數(shù)為5,當(dāng)創(chuàng)建第6條連接時(shí),由于連接池中連接數(shù)量已經(jīng)達(dá)到了最大數(shù)并且沒(méi)有空閑的連接,因此需要等待連接直到超時(shí)。當(dāng)超過(guò)超時(shí)時(shí)間時(shí),就出現(xiàn)了上述的連接異常。因此,我必須再次強(qiáng)調(diào),使用完的連接應(yīng)當(dāng)盡快的正確的關(guān)閉和釋放。

?

5. 監(jiān)視SQL Server連接狀態(tài)的方法 (1)通過(guò)活動(dòng)監(jiān)視器

第一步:打開(kāi)MSSMS管理器,單擊“活動(dòng)監(jiān)視器”圖標(biāo)。

?

第二步:在打開(kāi)活動(dòng)監(jiān)視器視圖中,單擊“進(jìn)程”選項(xiàng)卡。

第三步:運(yùn)行?#4 連接池異常與處理方法?中的例子,則可以看到打開(kāi)的5條連接,如下圖所示。

?

(2)使用T-SQL語(yǔ)句

同樣,通過(guò)執(zhí)行系統(tǒng)存儲(chǔ)過(guò)程sp_who,我們也可以監(jiān)視連接狀態(tài)。

exec?sp_who

可得到以下結(jié)果:

?

?

6. 高效使用連接池的基本原則

????? 用好連接池將會(huì)大大提高應(yīng)用程序的性能。相反,如果使用不當(dāng)?shù)脑?,則百害而無(wú)一益。一般來(lái)說(shuō),應(yīng)當(dāng)遵循以下原則:

在最晚的時(shí)刻申請(qǐng)連接,在最早的時(shí)候釋放連接。關(guān)閉連接時(shí)先關(guān)閉相關(guān)用戶定義的事務(wù)。確保并維持連接池中至少有一個(gè)打開(kāi)的連接。盡力避免池碎片的產(chǎn)生。主要包括集成安全性產(chǎn)生的池碎片以及使用許多數(shù)據(jù)庫(kù)產(chǎn)生的池碎片。

提示:池碎片是許多 Web 應(yīng)用程序中的一個(gè)常見(jiàn)問(wèn)題,應(yīng)用程序可能會(huì)創(chuàng)建大量在進(jìn)程退出后才會(huì)釋放的池。 這樣,將打開(kāi)大量的連接,占用許多內(nèi)存,從而導(dǎo)致性能降低。

?

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過(guò)流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問(wèn)題卻十分常見(jiàn),不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問(wèn)題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問(wèn)題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來(lái)解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開(kāi)關(guān)電源具有效率高的特性,而且開(kāi)關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開(kāi)關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉