New Community Website

Ordinarily, you'd be at the right spot, but we've recently launched a brand new community website... For the community, by the community.

Yay... Take Me to the Community!

Welcome to the DNN Community Forums, your preferred source of online community support for all things related to DNN.
In order to participate you must be a registered DNNizen

HomeHomeArchived Discus...Archived Discus...Developing Under Previous Versions of .NETDeveloping Under Previous Versions of .NETASP.Net 2.0ASP.Net 2.0Timeout IssuesTimeout Issues
Previous
 
Next
New Post
5/28/2008 5:16 PM
 
Hi Folks, 

I have been struggling with a timeout problem for a week. Here is my first post on this issue where I got some pointers that moved me along the debugging path - http://www.dotnetnuke.com/Community/Forums/tabid/795/forumid/111/threadid/228684/scope/posts/Default.aspx. This is a pretty complex problem. I have a Microsoft GridView component that connects to a separate database (not the standard DNN DB). The major connection components to the SQL Server database are the main GridView, a nested GridView in each row, ObjectDataSource components, and the DNN data provider infrastructure. For the past week I have been running the site on my local hardware using VS 2005 debugger. One of my problems is that I have only gotten this to fail on my local site a couple of times. However there is one nuance that I think is the central part of my problem and seems to indicate that I don’t have a bug but that I am just overtaxing the database connections on my hosting site. In my nested GridView I have two DropDownLists. Although I ultimately get the data via an efficient SQL stored procedure they get loaded quite frequently. I have worked with relational databases for many years but I am not a professional DBA. However, it looks like this issue has to be solved at the application level. It seems I have two choices here – just eliminate the drop downs or save the data and drastically reduce the database proc executions. There is a fair amount of data in the drop downs but they do provide a convenience for users. Would expanding the connection pool make any sense if the hosting site can do that? I haven't done much with drop downs in web applications. Any suggestions?

Thanks for any help or suggestions,

G.M. 

Here is the error data from the DNN log on the hosting site for reference:
 

AssemblyVersion: 04.08.02
PortalID: 0
PortalName: IATSE Local 476
UserID: 5
UserName: local476
ActiveTabID: 68
ActiveTabName: Members
RawURL: /Default.aspx?tabid=68&error=Exception+has+been+thrown+by+the+target+of+an+invocation.
AbsoluteURL: /Default.aspx
AbsoluteURLReferrer: http://www.iatse476.org/Default.aspx?tabid=68&ctl=Edit&mid=454
UserAgent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322; .NET CLR 2.0.50727)
DefaultDataProvider: DotNetNuke.Data.SqlDataProvider, DotNetNuke.SqlDataProvider
ExceptionGUID: 39597839-ce7f-42c9-91bc-4e4ca1cc868b
InnerException: Exception has been thrown by the target of an invocation.
FileName:
FileLineNumber: 0
FileColumnNumber: 0
Method: System.Data.ProviderBase.DbConnectionFactory.GetConnection
StackTrace:
Message: DotNetNuke.Services.Exceptions.PageLoadException: Exception has been thrown by the target of an invocation. ---> System.Reflection.TargetInvocationException: Exception has been thrown by the target of an invocation. ---> System.InvalidOperationException: 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. at System.Data.ProviderBase.DbConnectionFactory.GetConnection(DbConnection owningConnection) at System.Data.ProviderBase.DbConnectionClosed.OpenConnection(DbConnection outerConnection, DbConnectionFactory connectionFactory) at System.Data.SqlClient.SqlConnection.Open() at Microsoft.ApplicationBlocks.Data.SqlHelper.ExecuteReader(String connectionString, CommandType commandType, String commandText, SqlParameter[] commandParameters) at Microsoft.ApplicationBlocks.Data.SqlHelper.ExecuteReader(String connectionString, String spName, Object[] parameterValues) at SSCI.Modules.SSCITableMod.SqlDataProvider.GetPgMembers(String sortExpression, Int32 startRowIndex, Int32 maximumRows, String searchArgLN, String searchArgJC, String typeArg, String Msg) at SSCI.Modules.SSCITableMod.SSCITableModController.GetPgMembers(String sortExpression, Int32 startRowIndex, Int32 maximumRows, String searchArgLN, String searchArgJC, String typeArg) --- End of inner exception stack trace --- at System.RuntimeMethodHandle._InvokeMethodFast(Object target, Object[] arguments, SignatureStruct& sig, MethodAttributes methodAttributes, RuntimeTypeHandle typeOwner) at System.RuntimeMethodHandle.InvokeMethodFast(Object target, Object[] arguments, Signature sig, MethodAttributes methodAttributes, RuntimeTypeHandle typeOwner) at System.Reflection.RuntimeMethodInfo.Invoke(Object obj, BindingFlags invokeAttr, Binder binder, Object[] parameters, CultureInfo culture, Boolean skipVisibilityChecks) at System.Reflection.RuntimeMethodInfo.Invoke(Object obj, BindingFlags invokeAttr, Binder binder, Object[] parameters, CultureInfo culture) at System.Web.UI.WebControls.ObjectDataSourceView.InvokeMethod(ObjectDataSourceMethod method, Boolean disposeInstance, Object& instance) at System.Web.UI.WebControls.ObjectDataSourceView.ExecuteSelect(DataSourceSelectArguments arguments) at System.Web.UI.DataSourceView.Select(DataSourceSelectArguments arguments, DataSourceViewSelectCallback callback) at System.Web.UI.WebControls.DataBoundControl.PerformSelect() at System.Web.UI.WebControls.BaseDataBoundControl.DataBind() at System.Web.UI.WebControls.GridView.DataBind() at System.Web.UI.WebControls.BaseDataBoundControl.EnsureDataBound() at System.Web.UI.WebControls.CompositeDataBoundControl.CreateChildControls() at System.Web.UI.Control.EnsureChildControls() at System.Web.UI.Control.PreRenderRecursiveInternal() at System.Web.UI.Control.PreRenderRecursiveInternal() at System.Web.UI.Control.PreRenderRecursiveInternal() at System.Web.UI.Control.PreRenderRecursiveInternal() at System.Web.UI.Control.PreRenderRecursiveInternal() at System.Web.UI.Control.PreRenderRecursiveInternal() at System.Web.UI.Control.PreRenderRecursiveInternal() at System.Web.UI.Control.PreRenderRecursiveInternal() at System.Web.UI.Control.PreRenderRecursiveInternal() at System.Web.UI.Control.PreRenderRecursiveInternal() at System.Web.UI.Control.PreRenderRecursiveInternal() at System.Web.UI.Control.PreRenderRecursiveInternal() at System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) --- End of inner exception stack trace ---
Source:
Server Name: GENERIC28

 

 

 
 
New Post
5/28/2008 7:21 PM
 

Hi George,

If I were in your shoes I would attach a profiler to my database server and evaluate exactly what is being executed, how many times, and at what cost.  Are you by chance using a non-express version of SQL Server?

Have you considered caching some of the data you're using to generate your dropdowns?

Brandon


Brandon Haynes
BrandonHaynes.org
 
New Post
5/28/2008 11:35 PM
 

Thanks for the quick reply Brandon. I checked the procs that fill the DropDownLists using the VS 2005 debugger and SQL Profiler. There is no doubt they are getting executed a lot. Caching makes sense at least as a first try. One minor problem is that I got the data from an old file where the data lists were not standardized, i.e. the users just typed in various job and certification descriptions using different abbreviations, etc. You would be surprised how many versions of the same thing are in the lists with different spellings. The bottom line is that for caching to work reasonably well the lists should be cut down. I hope I can get some help from my customer but I have a feeling I am about to do some grunt work. At any rate it's a good suggestion.

I haven’t worked with the Asp.Net DropDownList before or tried caching the data for it. I did find a couple of articles on it and I’ll check them out. If you have any favorite articles or tutorials, let me know and I’ll read them.

Thanks,

G.M.

 

 
New Post
5/29/2008 10:52 AM
 

Hi George,

I probably should have mentioned this in my previous post, but you'll probably also want to load a sample workload in MSQLS's database engine tuning advisor and see if the advisor can catch any missing or inappropriate indices or other optimizations.  You'd be surprised what the tuner can find.  If you're using MSSQL 2000, I believe you'd do that in the query analyzer.

As far as caching, the best solution really depends on your design and specific needs.  For a small application, a cached disconnected dataset might be appropriate.  A more rigorous solution would involve the conversion of data into business objects and the caching those business objects.  I suppose an XML document could work as well, but you don't want to create overhead that exceeds the use of the SP in the first place.

You might also look into the ASP.Net Ajax Toolkit Autocomplete Extender and see if it might help.

Hope this helps!

Brandon


Brandon Haynes
BrandonHaynes.org
 
New Post
5/29/2008 11:33 AM
 

George,

In your stored procedure are you selecting just what you need, or are you doing a 'select * ...'. That can make a difference.  I also agree with Brandon; run the SQL Server Profiler to verify what you are really requesting from the Database.

 

Best regards,

Sean Gahan
http://seangahan.net

 
Previous
 
Next
HomeHomeArchived Discus...Archived Discus...Developing Under Previous Versions of .NETDeveloping Under Previous Versions of .NETASP.Net 2.0ASP.Net 2.0Timeout IssuesTimeout Issues


These Forums are dedicated to discussion of DNN Platform and Evoq Solutions.

For the benefit of the community and to protect the integrity of the ecosystem, please observe the following posting guidelines:

  1. No Advertising. This includes promotion of commercial and non-commercial products or services which are not directly related to DNN.
  2. No vendor trolling / poaching. If someone posts about a vendor issue, allow the vendor or other customers to respond. Any post that looks like trolling / poaching will be removed.
  3. Discussion or promotion of DNN Platform product releases under a different brand name are strictly prohibited.
  4. No Flaming or Trolling.
  5. No Profanity, Racism, or Prejudice.
  6. Site Moderators have the final word on approving / removing a thread or post or comment.
  7. English language posting only, please.