时间:2021-07-01 10:21:17 帮助过:5人阅读
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三次握手连接,因为连接池起了作用。
在上图书我标示TSL:Handshake为TCP握手,这是错误的,真正的TCP握手应该是
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://www.cnblogs.com/xwdreamer/archive/2012/08/07/2626610.html
[转载].net下数据库连接池
标签: