网上找了好久,关于.net数据库连接池的资料网上很少,真是让人纳闷,java的网上一收就是一大堆,.net的怎么找不到呢,难到。。。。
最后还是被我发现了:ado.net 本就有连接功能,所有.net开法基本不用去考虑连接问题,怪不得.net的连接池资料网上找不到。.net连接池只要在连接字符串里配制就可以了:

以连接字符串关键字控制Connection Pool

ConnectionString属性是SQLConnection 对象的一个属性,它支持一个连接串/值对,这个对是用于调整connection pool行为的。下表是ConnectionString 的值及解释。

名称
 默认值
 描述
 
Connection Lifetime
 0
 当连接返回pool时,它的时间和创建时间相比,如果它的存在时间超过了Connection Lifetime,它被释放。这对于新加入集群的服务器平衡是很有用的。值0可以保证连接有最大时限。
 
Connection Reset
 'true'
 决定从pool移走时数据库连接是否被重置。
 
Enlist
 'true'
 为true时pooler自动列出当前创建线程的操作上下文,如果操作上下文存在的话。
 
Max Pool Size
 100
 Pool中允许的最大连接数。
 
Min Pool Size
 0
 Pool中允许的最小连接数。
 
Pooling
 'true'
 为true时,连接从相应的pool中被取出,如果需要将创建或添加到相应的池中。
 

Connection Pool的性能记数器

SQL Server .NET Data Provider添加了一些性能记数器使用户可以调整connection pool特性。下面是一些记数器:

记数器
 描述
 
SqlClient: 缓冲的和非缓冲的连接数
 当前的连接数
 
SqlClient: 当前缓冲的连接数
 在池中与当前进程关联的所有连接
 
SqlClient: 当前connection pool数
 与当前进程连接的池数
 
SqlClient: 最大缓冲连接数
 从进程开始以来使用的最大连接数。此记数器只有在与特定进程关联时才有意义。_Global 实例总返回0
 
SqlClient: 总失败连接数
 失败总数