首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从池获得连接之前经过的超时时间。

从池获得连接之前经过的超时时间。
EN

Stack Overflow用户
提问于 2011-03-26 11:17:37
回答 1查看 23.6K关注 0票数 13

我发现了一个错误:

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

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

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-03-26 11:39:43

此错误意味着连接池已断开连接。通常的原因是在使用连接后忘记关闭连接,例如:

代码语言:javascript
运行
复制
var con = new MySqlConnection("Server=YourDB;Database=YourDb;...");
con.Open();
var com = con.CreateCommand();
com.CommandText = "select * from YourTable";

此代码忘记关闭连接,因此池少了一个连接。您可以通过添加以下内容来解决这个问题:

代码语言:javascript
运行
复制
con.Close();

在最后。但是,如果查询抛出异常,则Close将被跳过,而您仍然需要1连接。

一个更好的方法是using语句:

代码语言:javascript
运行
复制
using (var con = new MySqlConnection("Server=YourDB;Database=YourDb;..."))
{
    con.Open();
    var com = con.CreateCommand();
    com.CommandText = "select * from YourTable";
}

通过在连接测试的末尾添加max pool size,您可以轻松地排除故障,如下所示:

代码语言:javascript
运行
复制
Server=YourDB;Database=YourDbUid=YourUser;Pwd=YourPwd;max pool size=1;

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

票数 31
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5441946

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档