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

      }

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

posted @ 2009-05-27 09:55  老姜  阅读(9983)  评论(0编辑  收藏  举报