如何在c#項(xiàng)目中設(shè)置使用連接池-創(chuàng)新互聯(lián)

本篇文章為大家展示了如何在c#項(xiàng)目中設(shè)置使用連接池,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

成都創(chuàng)新互聯(lián)公司長(zhǎng)期為上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為鎮(zhèn)沅企業(yè)提供專業(yè)的網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè),鎮(zhèn)沅網(wǎng)站改版等技術(shù)服務(wù)。擁有十年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。

C#在連接字符串中設(shè)置連接池


    如果使用的是 OleDbConnection、OdbcConnection 或 OracleConnection 類,則連接池將由提供程序自動(dòng)處理,所以您不必自己進(jìn)行管理。

    如果使用的是 SqlConnection 類,則連接池被隱式管理,但也提供選項(xiàng)允許您自己管理池。

    連接使用Open()方法打開連接,這時(shí)候連接池就會(huì)初始化并建立設(shè)定的最小連接數(shù)。在使用完連接時(shí)一定要關(guān)閉連接,以便連接可以返回池。要關(guān)閉連接使用Close()

    當(dāng)連接數(shù)滿了并且申請(qǐng)連接的時(shí)間超過(guò)設(shè)置連接等待的時(shí)間時(shí),使用“異步進(jìn)程”,對(duì)數(shù)據(jù)庫(kù)進(jìn)行異步操作,確保連接能夠及時(shí)調(diào)用Close方法關(guān)閉連接,這樣能大大減少正在使用的連接數(shù)。

當(dāng)數(shù)據(jù)庫(kù)操作和訪問(wèn)頻繁的時(shí)候,減少創(chuàng)建連接和打開連接所耗的時(shí)間,提升數(shù)據(jù)庫(kù)服務(wù)器的性能。 這里將詳細(xì)分析C#數(shù)據(jù)庫(kù)連接池。

使用C#數(shù)據(jù)庫(kù)連接池

連接到數(shù)據(jù)庫(kù)服務(wù)器通常由幾個(gè)需要軟長(zhǎng)時(shí)間的步驟組成。必須建立物理通道(例如套接字或命名管道),必須與服務(wù)器進(jìn)行初次連接,必須分析連接字符串信息,必須由服務(wù)器對(duì)連接進(jìn)行身份驗(yàn)證,等等。

實(shí)際上,大部份的應(yīng)用程序都是使用一個(gè)或幾個(gè)不同的連接配置。當(dāng)應(yīng)用程序的數(shù)據(jù)量和訪問(wèn)量大的時(shí)候,這意味著在運(yùn)行應(yīng)用程序的過(guò)程中,許多相同的連接將反 復(fù)地被打開和關(guān)閉,從而會(huì)引起數(shù)據(jù)庫(kù)服務(wù)器效率低下甚至引發(fā)程序崩潰。為了確保應(yīng)用程序的穩(wěn)定和降低性能成本,我們可以在ADO.NET中使用稱為連接池的優(yōu)化方法來(lái)管理維護(hù)連接。

C#數(shù)據(jù)庫(kù)連接池可以減少創(chuàng)建連接的次數(shù)。定義最小連接數(shù)(固定連接數(shù)),當(dāng)用戶在連接上調(diào)用Open,連接池就會(huì)檢查池中是否有可用的連接。如果發(fā)現(xiàn)有連接可用,會(huì)將該連接返回給調(diào)用者,而不是創(chuàng)建新連接。應(yīng)用程序在該連接上調(diào)用Close時(shí),連接池會(huì)判斷該連接是否在最小連接數(shù)之內(nèi),如果“是”會(huì)將連接回收到活動(dòng)連接池中而不是真正關(guān)閉連接,否則將燒毀連接。連接返回到池中之后,即可在下一個(gè)Open調(diào)用中重復(fù)使用。

創(chuàng)建C#數(shù)據(jù)庫(kù)連接池

以下示例使用C#連接SQL數(shù)據(jù)庫(kù):

 class DbConn
    {
        //using System.Data;
        //using System.Data.SqlClient;
        private const int MaxPool = 10;         //較大連接數(shù)
        private const int MinPool = 5;          //最小連接數(shù)
        private const bool Asyn_Process = true; //設(shè)置異步訪問(wèn)數(shù)據(jù)庫(kù)
        private const bool Mars = true;         //在單個(gè)連接上得到和管理多個(gè)、僅向前引用和只讀的結(jié)果集(ADO.NET2.0) 
        private const int Conn_Timeout = 15;    //設(shè)置連接等待時(shí)間
        private const int Conn_Lifetime = 15;   //設(shè)置連接的生命周期
        private string ConnString = "";         //連接字符串      
        private SqlConnection SqlDrConn = null;  //連接對(duì)象

        public DbConn()//構(gòu)造函數(shù)
        {
            ConnString = GetConnString();
            SqlDrConn = new SqlConnection(ConnString);
        }

        private string GetConnString()
        {
            return "server=localhost;"
                + "integrated security=sspi;"
                + "database=pubs;"
                + "Max Pool Size=" + MaxPool + ";"
                + "Min Pool Size=" + MinPool + ";"
                + "Connect Timeout=" + Conn_Timeout + ";"
                + "Connection Lifetime=" + Conn_Lifetime + ";"
                +"Asynchronous Processing=" + Asyn_Process + ";";
                //+ "MultipleActiveResultSets=" + Mars + ";";
        }
       
        public DataTable GetDataReader(string StrSql)//數(shù)據(jù)查詢
        {                    
            //當(dāng)連接處于打開狀態(tài)時(shí)關(guān)閉,然后再打開,避免有時(shí)候數(shù)據(jù)不能及時(shí)更新
            if (SqlDrConn.State == ConnectionState.Open)
            {
                SqlDrConn.Close();                
            }
            try
            {
                SqlDrConn.Open();
                SqlCommand SqlCmd = new SqlCommand(StrSql, SqlDrConn);
                SqlDataReader SqlDr = SqlCmd.ExecuteReader();
                if (SqlDr.HasRows)
                {
                    DataTable dt = new DataTable();
                    //讀取SqlDataReader里的內(nèi)容
                    dt.Load(SqlDr);
                    //關(guān)閉對(duì)象和連接
                    SqlDr.Close();
                    SqlDrConn.Close();                    
                    return dt;
                }
                return null;
            }
            catch (Exception ex)
            {
                System.Windows.Forms.MessageBox.Show(ex.Message);          
                return null;
            }
            finally
            {        
                SqlDrConn.Close();
            }
        }
    }

通過(guò)調(diào)用SqlDrConn.Open()方法打開連接,這時(shí)候連接池就會(huì)初始化并建立設(shè)定的最小連接數(shù)。想更清楚了解到連接池的 狀況可以通過(guò)SQL的查詢分析器執(zhí)行存儲(chǔ)過(guò)程sp_Who,它會(huì)列出當(dāng)前的數(shù)據(jù)庫(kù)進(jìn)程,查看loginname、dbname可以區(qū)分用戶的連接信息,但 要注意的是登錄查詢分析器本身會(huì)使用兩個(gè)連接,所以好用另一個(gè)用戶名登錄查詢分析器。使用此方法還有一個(gè)麻煩地方就是要經(jīng)常按“執(zhí)行查詢”以更新進(jìn)程信 息。還有另一種方法個(gè)人認(rèn)為較好的,通過(guò)控制面板→管理工具→性能,右擊添加計(jì)算器,性能對(duì)象選擇 SQlServer:GeneralStatistics(常規(guī)統(tǒng)計(jì))然后計(jì)算器選擇UserConnections(用戶連接)最后按“添加”就可以實(shí) 時(shí)查看當(dāng)前連接數(shù)。

到了這里,連接池已經(jīng)實(shí)現(xiàn)了,但問(wèn)題往往會(huì)出現(xiàn)在運(yùn)行過(guò)程中。如連接池的連接數(shù)滿 了該怎樣處理?在這里我們應(yīng)該合理設(shè)置連接字符串中的ConnectTimeout屬性和ConnectionLifetime屬性(上面有解釋)延長(zhǎng)等 待時(shí)間,盡可能地在每次使用完連接之后調(diào)用Close方法關(guān)閉連接。但從中也有沒(méi)法避免的,當(dāng)連接數(shù)滿了并且申請(qǐng)連接的時(shí)間超過(guò)設(shè)置連接等待的時(shí)間時(shí),程 序?qū)?huì)引發(fā)InvalidOperationExceptio異常,我們可以通過(guò)捕獲此異常向用戶界面提示“系統(tǒng)正忙,請(qǐng)稍后再連接……”之類的信息來(lái)緩 解這種情況。此外,也有另一種方法來(lái)解決這種情況,就是利用ADO.NET2.0新特性“異步進(jìn)程”,對(duì)數(shù)據(jù)庫(kù)進(jìn)行異步操作,確保連接能夠及時(shí)調(diào)用 Close方法關(guān)閉連接,這樣能大大減少正在使用的連接數(shù)。

使用方法:在連接字符串中加上AsynchronousProcessing=true表示使用異步處理操作。

當(dāng)應(yīng)用程序不再需要用到連接池的時(shí)候可以使用ClearPool或ClearAllPools方法清空連接池也可作重置連接池使用,方法如下:

SqlConnection.ClearPool(SqlConnectionconnection)清空關(guān)聯(lián)的連接池

SqlConnection.ClearAllPools()清空所有連接池

調(diào)用上述方法,如果連接正在使用,連接池會(huì)做相應(yīng)標(biāo)記,等連接關(guān)閉時(shí)自動(dòng)燒毀。

小結(jié)C#數(shù)據(jù)庫(kù)連接池

優(yōu)點(diǎn):當(dāng)數(shù)據(jù)庫(kù)操作和訪問(wèn)頻繁的時(shí)候,減少創(chuàng)建連接和打開連接所耗的時(shí)間,提升數(shù)據(jù)庫(kù)服務(wù)器的性能。

缺點(diǎn):數(shù)據(jù)庫(kù)連接池中可能存在著多個(gè)沒(méi)有被使用的連接一直連接著數(shù)據(jù)庫(kù),這意味著資源的浪費(fèi)。

上述內(nèi)容就是如何在c#項(xiàng)目中設(shè)置使用連接池,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)頁(yè)標(biāo)題:如何在c#項(xiàng)目中設(shè)置使用連接池-創(chuàng)新互聯(lián)
文章鏈接:http://muchs.cn/article8/ceoeip.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、動(dòng)態(tài)網(wǎng)站網(wǎng)站營(yíng)銷、企業(yè)網(wǎng)站制作自適應(yīng)網(wǎng)站、網(wǎng)頁(yè)設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)