国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

[轉載].net下數據庫連接池

2019-11-17 02:10:41
字體:
來源:轉載
供稿:網友

[轉載].net下數據庫連接池

之前寫過一篇博客數據庫連接池分析分析了,通過代碼來分析數據庫連接池的作用。

這里要搞清楚一個概念,數據庫連接池并不是數據庫服務的內容,而是客戶端應用程序創建的一種應用架構。

所以我們在數據庫服務器上找不到什么開啟數據庫連接池的選項。

接下來將開啟與不開啟數據庫連接池的區別。

使用數據庫連接池

復制代碼
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Data.SqlClient;namespace ConnectionPool{    class PRogram    {        static void Main(string[] args)        {            string connectionString3 = "Data Source=jackal-pc;Initial Catalog=xwdb;User Id=xuwei;PassWord=1234;";            string connectionString2 = "Data Source=jackal-pc;Initial Catalog=xwdb;User Id=xuwei2;Password=xuwei2;";             using (SqlConnection connection = new SqlConnection(connectionString3))            {                //打開連接                connection.Open();                Console.WriteLine("建立連接1");                SqlCommand sqlcmd = connection.CreateCommand();                sqlcmd.CommandText = "select @@version;";                SqlDataReader sqlreader = sqlcmd.ExecuteReader();            }            using (SqlConnection connection = new SqlConnection(connectionString2))            {                //打開連接                connection.Open();                Console.WriteLine("建立連接2");                SqlCommand sqlcmd = connection.CreateCommand();                sqlcmd.CommandText = "select @@version;";                SqlDataReader sqlreader = sqlcmd.ExecuteReader();            }            using (SqlConnection connection = new SqlConnection(connectionString3))            {                //打開連接                connection.Open();                Console.WriteLine("建立連接1");                SqlCommand sqlcmd = connection.CreateCommand();                sqlcmd.CommandText = "select @@version;";                SqlDataReader sqlreader = sqlcmd.ExecuteReader();            }        }    }}
復制代碼

在connectiongString中數據庫連接池默認就是開啟的,也就是Pooling=true;只有要關閉數據庫連接池的時候,才需要顯示聲明Pooling=false;

通過netmon抓取網絡報如下

通過上圖我們可以發現,三次連接,但是網絡中只有兩次連接,這是因為第三次連接字符串跟第一次一樣,所以使用了數據連接池。我們可以看到最后的兩次SQLBatch是連續的,兩次SQLBatch之間沒有TCP三次握手連接,因為連接池起了作用。

PS:三次握手錯誤糾正

在上圖書我標示TSL:Handshake為TCP握手,這是錯誤的,真正的TCP握手應該是

  1. TCP:Flags=....S....
  2. TCP:Flags=....A..S
  3. TCP:Flags=....A....

不適用數據庫連接池

復制代碼
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Data.SqlClient;namespace ConnectionPool{    class Program    {        static void Main(string[] args)        {            string connectionString3 = "Data Source=jackal-pc;Initial Catalog=xwdb;User Id=xuwei;Password=1234;Pooling=false;";            string connectionString2 = "Data Source=jackal-pc;Initial Catalog=xwdb;User Id=xuwei2;Password=xuwei2;Pooling=false;";             using (SqlConnection connection = new SqlConnection(connectionString3))            {                //打開連接                connection.Open();                Console.WriteLine("建立連接1");                SqlCommand sqlcmd = connection.CreateCommand();                sqlcmd.CommandText = "select @@version;";                SqlDataReader sqlreader = sqlcmd.ExecuteReader();            }            using (SqlConnection connection = new SqlConnection(connectionString2))            {                //打開連接                connection.Open();                Console.WriteLine("建立連接2");                SqlCommand sqlcmd = connection.CreateCommand();                sqlcmd.CommandText = "select @@version;";                SqlDataReader sqlreader = sqlcmd.ExecuteReader();            }            using (SqlConnection connection = new SqlConnection(connectionString3))            {                //打開連接                connection.Open();                Console.WriteLine("建立連接1");                SqlCommand sqlcmd = connection.CreateCommand();                sqlcmd.CommandText = "select @@version;";                SqlDataReader sqlreader = sqlcmd.ExecuteReader();            }        }    }}
復制代碼

如上圖所示,有三次數據庫連接,然后通過netmon抓取網絡包發現又3次的TCP三次握手連接,這證明是沒有使用連接池,每一次連接結束都會關閉連接。下次即使使用相同的連接也要重現新建連接。創建連接比較消耗資源,如果頻繁地創建關閉連接會影響性能。

轉載自:http://m.survivalescaperooms.com/xwdreamer/archive/2012/08/07/2626610.html


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 娱乐| 青川县| 全南县| 嘉黎县| 林甸县| 临漳县| 台山市| 乌海市| 汉阴县| 丰县| 南雄市| 武邑县| 延长县| 比如县| 衡南县| 响水县| 五家渠市| 武山县| 河池市| 灵璧县| 威信县| 土默特右旗| 溧阳市| 桂东县| 大竹县| 莒南县| 马龙县| 武邑县| 永寿县| 钟山县| 梁平县| 永泰县| 民和| 鞍山市| 金门县| 静安区| 子洲县| 司法| 黄山市| 恩施市| 乌兰浩特市|