之前寫過一篇博客數據庫連接池分析 分析了,通過代碼來分析數據庫連接池的作用。
這里要搞清楚一個概念,數據庫連接池並不是數據庫服務的內容,而是客戶端應用程序創建的一種應用架構。
所以我們在數據庫服務器上找不到什么開啟數據庫連接池的選項。
接下來將開啟與不開啟數據庫連接池的區別。
使用數據庫連接池

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握手應該是
- TCP:Flags=....S....
- TCP:Flags=....A..S
- 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三次握手連接,這證明是沒有使用連接池,每一次連接結束都會關閉連接。下次即使使用相同的連接也要重現新建連接。創建連接比較消耗資源,如果頻繁地創建關閉連接會影響性能。