我收到了错误:
错误连接:超时已过期.从池中获取连接之前经过的超时时间.这可能是因为所有池连接都在使用中并且达到了最大池大小.
每当我在浏览器中等待响应很长时间后停止IIS时,它就会出现.如果我试图等待,那么我得到的错误,An unhandled exception of type 'System.StackOverflowException' occurred in mscorlib.dll但我得到的错误写得很旧.我只写了一个没有任何异常的新命令.[我认为第一次运行错误首先出现错误,所以所有新错误都不能给出异常].
所以我需要做些什么才能解决这个问题.
And*_*mar 29
该错误表示连接池没有连接.通常的原因是在使用后忘记关闭连接,例如:
var con = new MySqlConnection("Server=YourDB;Database=YourDb;...");
con.Open();
var com = con.CreateCommand();
com.CommandText = "select * from YourTable";
Run Code Online (Sandbox Code Playgroud)
此代码忘记关闭连接,因此池连接较少.你可以通过添加:
con.Close();
Run Code Online (Sandbox Code Playgroud)
在末尾.但是如果查询引发异常,Close则会跳过,并且您仍然处于1连接状态.
using声明是一个更好的方法:
using (var con = new MySqlConnection("Server=YourDB;Database=YourDb;..."))
{
con.Open();
var com = con.CreateCommand();
com.CommandText = "select * from YourTable";
}
Run Code Online (Sandbox Code Playgroud)
您可以通过max pool size在连接结束时添加来轻松解决此问题,例如:
Server=YourDB;Database=YourDbUid=YourUser;Pwd=YourPwd;max pool size=1;
Run Code Online (Sandbox Code Playgroud)
这使您的池大小为1,如果您忘记释放一个连接,则会立即触发错误情况.