24

我在 asp.net 3.5 中有一个应用程序,数据库是 Sql server 2005。

"Timeout expired.  The timeout period elapsed prior to obtaining a connection from the pool.  This may have occurred because all pooled connections were in use and max pool size was reached."

有时会发生此错误如何解决此错误..

我尝试SqlConnection.ClearAllPools();了,但这也不起作用。

SqlCommand cmdToExecute = new SqlCommand();
            cmdToExecute.CommandText = "dbo.[sp_user_listing]";
            cmdToExecute.CommandType = CommandType.StoredProcedure;
            DataTable toReturn = new DataTable("courier_user_listing");
            SqlDataAdapter adapter = new SqlDataAdapter(cmdToExecute);

            // Use base class' connection object
            cmdToExecute.Connection = sqMainConnection;

            try
            {
                cmdToExecute.Parameters.Add(new SqlParameter("@suser_name", SqlDbType.VarChar, 250, ParameterDirection.Input, true, 0, 0, "", DataRowVersion.Proposed, _user_name));


                if (blnMainConnectionIsCreatedLocal)
                {
                    // Open connection.
                    sqMainConnection.Open();
                }
                else
                {
                    if (CPMainConnectionProvider.IsTransactionPending)
                    {
                        cmdToExecute.Transaction = CPMainConnectionProvider.CurrentTransaction;
                    }
                }

                // Execute query.
                adapter.Fill(toReturn);
                i32ErrorCode = (Int32)cmdToExecute.Parameters["@iErrorCode"].Value;

                if (i32ErrorCode != (int)LLBLError.AllOk)
                {
                    // Throw error.
                    throw new Exception("Stored Procedure 'sp_courier_user_SelectAll' reported the ErrorCode: " + i32ErrorCode);
                }

                return toReturn;
            }
            catch (Exception ex)
            {
                // some error occured. Bubble it to caller and encapsulate Exception object
                throw new Exception("Courier_user::SelectAll::Error occured.", ex);
            }
            finally
            {
                if (blnMainConnectionIsCreatedLocal)
                {
                    // Close connection.
                    sqMainConnection.Close();
                }
                cmdToExecute.Dispose();
                adapter.Dispose();
            }
4

4 回答 4

14

检查数据库中任何长时间运行的查询。

增加你的池大小只会让你的 webapp 寿命更长一点(并且可能会变得更慢)

您可以使用 sql server profiler 并过滤持续时间/读取以查看哪些查询需要优化。

我还看到您可能正在保持全球联系?

blnMainConnectionIsCreatedLocal

让 .net 为您进行池化,并使用 using 语句打开/关闭您的连接。

建议:

  1. 始终像这样打开和关闭连接,因此 .net 可以管理您的连接,并且您不会用完连接:

        using (SqlConnection conn = new SqlConnection(connectionString))
        {
         conn.Open();
         // do some stuff
        } //conn disposed
    
  2. 正如我所提到的,使用sql server profiler检查您的查询,看看您是否可以优化它。在 Web 应用程序中对许多请求进行慢速查询也会导致这些超时。

于 2013-04-06T07:41:05.933 回答
12

这也是你可以尝试的......

运行您的应用程序....当它仍在运行时启动您的命令提示符

当您的应用程序运行时,在命令提示符下键入netstat -n。您应该会看到 TCP/IP 连接列表。检查您的列表是否不是很长。理想情况下,列表中的连接数应少于 5 个。检查连接的状态。
如果您有太多处于 TIME_WAIT 状态的连接,则表示连接已关闭并正在等待操作系统释放资源。如果您在 Windows 上运行,则默认临时端口范围在 1024 和 5000 之间,Windows 从 TIME_WAIT 状态释放资源的默认时间为 4 分钟。因此,如果您的应用程序在不到 4 分钟的时间内使用了超过 3976 个连接,您将得到异常。

修复它的建议:

  1. 将连接池添加到您的连接字符串。

如果您继续收到相同的错误消息(这极不可能),您可以尝试以下操作:(如果您不熟悉 Windows 注册表,请不要这样做)

  1. 从运行命令运行regedit 。在注册表编辑器中查找此注册表项:HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters:

修改设置,使其显示为:

MaxUserPort = dword:00004e20(十进制 10,000) TcpTimedWaitDelay = dword:0000001e(十进制 30)

这会将端口数增加到 10,000,并减少释放释放的 tcp/ip 连接的时间。

如果 1 失败,仅使用建议 2。

谢谢你。

于 2013-04-06T13:11:17.313 回答
6

可能这是所有时间的多连接打开问题,您在代码中的某个位置打开连接并且没有正确关闭它们。采用

 using (SqlConnection con = new SqlConnection(connectionString))
        {
            con.Open();
         }

请参考这篇文章: http: //msdn.microsoft.com/en-us/library/ms254507 (v=vs.80).aspx ,Visual Basic 或 C# 中的 Using 块会在代码退出块时自动处理连接,即使在未处理的异常的情况下。

于 2013-04-06T07:41:20.510 回答
5

在你开始诅咒你的应用程序之前,你需要检查一下:

  1. 您的应用程序是唯一使用该 SQL Server 实例的应用程序吗?一种。如果答案是否定的,那么您需要调查其他应用程序如何消耗您的 SQl Server.run b 上的资源。如果答案是肯定的,那么您必须调查您的申请。

  2. 运行 SQL Server Profiler 并使用 SQL Server 检查其他应用程序 (1a) 中发生的活动,并检查您的应用程序 (1b)。

  3. 如果您的应用程序确实缺乏资源,那么您需要进行进一步的调查。有关此http://sqlserverplanet.com/troubleshooting/sql-server-slowness的更多信息

于 2013-04-06T11:39:44.160 回答