FIX: Performance Degrades When You Call Methods of a ServicedComponent (327782)



The information in this article applies to:

  • Microsoft .NET Framework 1.0 SP1
  • Microsoft .NET Framework 1.0 SP2

This article was previously published under Q327782

SYMPTOMS

When you make a call from a remote .NET AppDomain to a Microsoft .NET component that is configured in COM+, you may experience performance slowdown in the AppDomain that initiated the call. This problem occurs only when you invoke methods on a ServicedComponent that is hosted by a COM+ server application.

CAUSE

When a managed application dispatches method calls to a ServicedComponent that is hosted in a COM+ server application, the .NET Framework must marshal method parameters. To improve performance, the internal marshaling layer uses a cached MemoryStream object to marshal and unmarshal the parameters. However, the marshaler always uses the full MemoryStream buffer for every call, instead of passing only the minimum required data.

Because the marshaled stream can become larger than necessary, applications that use large parameters at one time may experience performance degradation for calls that use small parameters later.

RESOLUTION

A supported fix is now available from Microsoft, but it is only intended to correct the problem that is described in this article. Apply it only to computers that are experiencing this specific problem. This fix may receive additional testing. Therefore, if you are not severely affected by this problem, Microsoft recommends that you wait for the next .NET Framework service pack that contains this fix.

To resolve this problem immediately, contact Microsoft Product Support Services to obtain the fix. For a complete list of Microsoft Product Support Services phone numbers and information about support costs, visit the following Microsoft Web site:NOTE: In special cases, charges that are ordinarily incurred for support calls may be canceled if a Microsoft Support Professional determines that a specific update will resolve your problem. The typical support costs will apply to additional support questions and issues that do not qualify for the specific update in question.

The English version of this fix has the file attributes (or later) that are listed in the following table. The dates and times for these files are listed in coordinated universal time (UTC). When you view the file information, it is converted to local time. To find the difference between UTC and local time, use the Time Zone tab in the Date and Time tool in Control Panel.
   Date          Time    Version        Size      File name
   ----------------------------------------------------------------------------------
   10-Aug-2002   09:51   1.0.3705.302   208,896   System.EnterpriseServices.dll
   09-Aug-2002   23:23   1.0.3705.302    47,104   System.EnterpriseServices.Thunk.dll
				

This fix is designed specifically to be installed on a system that already has the Microsoft .NET Framework Service Pack 1 installed. If you must have this fix on a system that has Microsoft .NET Framework Service Pack 2 installed, click the article number below to view the article in the Microsoft Knowledge Base:

328545 INFO: Post-Service Pack 2 .NET Framework Hotfix Rollup Package 2

STATUS

Microsoft has confirmed that this is a problem in the Microsoft products that are listed at the beginning of this article.

MORE INFORMATION

Steps to Reproduce the Behavior

The following is minimal information relevant to demonstrating the problem that is discussed in this article. For additional information about how to create ServicedComponents, click the article number below to view the article in the Microsoft Knowledge Base:

306296 HOW TO: Create a Serviced .NET Component in Visual C# .NET

To reproduce the problem, follow these steps:
  1. Use the following code to create a COM+ component:
    using System;
    using System.Reflection;
    using System.Runtime.CompilerServices;
    using System.EnterpriseServices;
    
    [assembly: AssemblyVersion("1.0.0.0")]
    [assembly: AssemblyKeyFile("ComPlusTest.snk")]
    
    [assembly: ApplicationName("ComPlusTest")]
    [assembly: ApplicationActivation(ActivationOption.Server)]
    
    public class CServer : ServicedComponent
    {
       [AutoComplete]
       public String Exec(byte [] param)
       {
    	return "done";
       }
    }
    					
  2. Use the following code to create a client application:
    using System;
    
    public class CClient
    {
       public static void Main()
       {
          CServer pObj = new CServer();
          byte [] pLarge = new byte [2000];
          byte [] pSmall = new byte [10];
    
          // method call with large param
          pObj.Exec(pLarge);
    
          // method call with small param
          // takes just as long as the earlier call
          pObj.Exec(pSmall);
    
          pObj.Dispose();
       }
    }
    					
Because of this bug, the second call to CServer.Exec takes as long as the first call, although the parameter is smaller.

Modification Type:MinorLast Reviewed:10/11/2005
Keywords:kbHotfixServer kbQFE kbbug kbfix kbNetFrame100preSP3fix kbQFE KB327782