公司的网站运行了一段时间,最近因为访问量大了不少,经常出现 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

      }

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

相关文章:

  • 2021-08-11
  • 2022-12-23
  • 2021-12-05
  • 2022-12-23
  • 2021-12-07
  • 2021-06-28
猜你喜欢
  • 2022-01-20
  • 2022-12-23
  • 2021-08-26
  • 2021-05-25
  • 2021-12-11
  • 2021-11-14
  • 2022-12-23
相关资源
相似解决方案