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

      }

      这样就一定不会出现错误。

原文地址:https://www.cnblogs.com/codehunter008/p/1490591.html