PRB: Server May Stop Responding or Get an Access Violation w/ Low Open Objects (181563)



The information in this article applies to:

  • Microsoft SQL Server 6.5

This article was previously published under Q181563

SYMPTOMS

SAP SQL Servers may experience any of the following symptoms if the 'open objects' configuration value for SQL Server is set too low:
  • Access violations.
  • SQL Server stops responding while operating under normal production.
  • SQL Server stops responding while doing DBCC CHECKDB().

CAUSE

The cause of the access violations and when SQL Server stops responding while the server is operating under normal production is believed to occur as a result of one or both of the following two known bugs:

BUG 17420, Concurrent Insert w/ Open Object Reuse May Cause Hang
BUG 17338, Problems with Server Cursors on a Stored Procedure


For more information on these bugs, see the articles in the Microsoft Knowledge Base listed in the MORE INFORMATION section of this article.

As of the writing of this article, a bug has not yet been filed for the third condition, when SQL Server stops responding while running a DBCC statement. However, it has been observed that an overlapping execution of DBCC CHECKCATALOG() will often aggravate this problem, if not serve as the catalyst for it to arise.

WORKAROUND

Generally, in advising a configuration setting for the 'open objects' configuration option, it is suggested that you find the sum total of all objects in the sysobjects tables for each database on the server, and set the 'open objects' parameter to at least that value. By default, the 31H Kernel sets the 'open objects' configuration value to 50,000 during SAP installation. Due to the heavy use of temporary objects by the SAP application, the configuration value for 'open objects' should be set to at least twice the sum of the total objects in all user databases, or 50,000, whichever is higher.

Additionally, if cursors are known to be in use on the server, enable Trace Flag 7502 for SQL Server.

To avoid the condition where SQL Server stops responding while running a DBCC statement, execute DBCC CHECKCATALOG() either before or after DBCC CHECKDB(), but do not start DBCC CHECKCATALOG() at the same time as DBCC CHECKDB(), nor while DBCC CHECKDB() is running.

MORE INFORMATION

For more information on Bug 17420, see the following article in the Microsoft Knowledge Base:

178296 : BUG: Concurrent Insert w/ Open Object Reuse May Cause Hang


For more information on Bug 17338, see the following article in the Microsoft Knowledge Base:

175126 : BUG: Problems with Server Cursors on a Stored Procedure


Modification Type:MajorLast Reviewed:10/3/2003
Keywords:kbprb KB181563 kbAudDeveloper