.netasp.netsql-serversql-server-2005

How can I solve a connection pool problem between ASP.NET and SQL Server?


The last few days we see this error message in our website too much:

"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."

We have not changed anything in our code in a while. I revised the code to check open connections which didn't close, but found everything to be fine.


Update:

Do I need to edit something in IIS?

Update:

I found that the number of active connections are anywhere from 15 to 31, and I found that the max allowed number of connections configured in SQL server is more than 3200 connections, is 31 too many or should I edit something in the ASP.NET configration?


Solution

  • In most cases connection pooling problems are related to connection leaks. Your application probably doesn't close its database connections correctly and consistently. When you leave connections open, they remain blocked until the .NET garbage collector closes them for you by calling their Finalize() method.

    You want to make sure that you are really closing the connection. For example the following code will cause a connection leak, if the code between .Open and Close throws an exception:

    var connection = new SqlConnection(connectionString);
    
    connection.Open();
    // some code
    connection.Close();                
    

    The correct way would be this:

    var connection = new SqlConnection(ConnectionString);
    
    try
    {
         connection.Open();
         someCall (connection);
    }
    finally
    {
         connection.Close();                
    }
    

    or

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

    When your function returns a connection from a class method make sure you cache it locally and call its Close method. You'll leak a connection using this code for example:

    var command = new OleDbCommand(someUpdateQuery, getConnection());
    
    result = command.ExecuteNonQuery();
    connection().Close(); 
    

    The connection returned from the first call to getConnection() is not being closed. Instead of closing your connection, this line creates a new one and tries to close it.

    If you use SqlDataReader or a OleDbDataReader, close them. Even though closing the connection itself seems to do the trick, put in the extra effort to close your data reader objects explicitly when you use them.


    This article "Why Does a Connection Pool Overflow?" from MSDN/SQL Magazine explains a lot of details and suggests some debugging strategies: