从池中获取连接之前经过的超时时间

时间:2011-03-26 11:17:37

标签: c# mysql sql

我收到了错误:

  

错误连接:超时已过期。从池中获取连接之前经过的超时时间。这可能是因为所有池连接都在使用中并且达到了最大池大小。

每当我在浏览器中等待响应很长时间后停止IIS时,就会出现这种情况。如果我试图等待,那么我得到了An unhandled exception of type 'System.StackOverflowException' occurred in mscorlib.dll的错误,但我得到的错误是写得很旧。我只写了一个没有任何异常的新命令。 [我认为第一次运行错误首先出现错误所以所有新错误都不能给出异常]。

所以我需要做些什么来解决这个问题。

1 个答案:

答案 0 :(得分:29)

错误表示连接池没有连接。通常的原因是在使用后忘记关闭连接,例如:

var con = new MySqlConnection("Server=YourDB;Database=YourDb;...");
con.Open();
var com = con.CreateCommand();
com.CommandText = "select * from YourTable";

此代码忘记关闭连接,因此池连接少一个。你可以通过添加:

来解决这个问题
con.Close();

最后。但是,如果查询引发异常,则会跳过Close,并且您仍然关闭1个连接。

更好的方法是using声明:

using (var con = new MySqlConnection("Server=YourDB;Database=YourDb;..."))
{
    con.Open();
    var com = con.CreateCommand();
    com.CommandText = "select * from YourTable";
}

您可以通过在连接结束时添加max pool size来轻松解决此问题,例如:

Server=YourDB;Database=YourDbUid=YourUser;Pwd=YourPwd;max pool size=1;

这使您的池大小为1,如果您忘记释放一个连接,则会立即触发错误情况。