The timeout period elapsed prior to obtaining a connection from the pool.数据库连接池满的原因
公司的网站运行了一段时间,最近因为访问量大了不少,经常出现 The timeout period elapsed prior to obtaining a connection from the pool.错误,这个错误一般就是连接池满了,估计就是程序中有的地方没有关闭连接造成的。
后来经过排查,开启了SQL 监视,发现一个存储过程经常挂起,调用该存储过程的C#代码方法(CheckUserLogin)使用了 DataReader,因为CheckUserLogin方法会经常被调用,而这里使用后又没有及时释放关闭DataReader,所以造成了连接池满。
建议以后在使用DataReader时候,要按照如下的形式写就不会出现问题。
using (SqlDataReader dr = SQLHelper.ExecuteReader(cmdText)){//在这里使用 dr
}
这样就一定不会出现错误。