FIX: 如果它们从 Session_End 事件调用,则可能会损坏对会话状态中存储的 STA 对象的引用

文章翻译 文章翻译
文章编号: 827164 - 查看本文应用于的产品
注意
为这篇文章的一个 Microsoft.net Framework 1.0 版本,请参阅 827163
本文已归档。它按“原样”提供,并且不再更新。
展开全部 | 关闭全部

本文内容

症状

如果您在会话状态中存储了您对单线程单元 (STA) 对象的引用,并且您将 AspCompat 属性设置为 true 引用可能会损坏,或当您试图从 Session_End 事件访问对象时,可能会丢失。

注意通常,如果运行在高负载下的应用程序,或者如果您使用一个压力工具,如应用程序中心测试 (活动),当您运行该应用程序时可能会出现此问题。 出现此问题时, 您会收到一个"0x8004e005 错误"事件日志中的错误消息。

原因

因为 Session_End 事件并没有在同一线程上创建该会话上运行的情况下出现问题。因为 STA 对象不再是在同一线程上创建该会话上,封送处理需要获得对该对象的访问。此行为会导致性能降低。

您可以将 STA 对象存储在会话状态中。但是,Microsoft 不建议您这样做。有关详细的信息,请参阅本文的"参考"一节。

解决方案

此修复程序将新的配置设置添加到 Machine.config 文件中。您安装此修复程序后,可用以下应用程序配置
<httpRuntime apartmentThreading=”true|false” />,
默认,apartmentThreading 设置为 false。如果设置为 trueapartmentThreading,就会出现以下行为:
  • 所有 Session_Start 事件相对应的 STA 线程上都运行的目标页或处理程序而不考虑在会话 ID。
  • 所有 Session_End 事件对应的 STA 线程上都运行会话 id。
  • AspCompat 成为设置为 true 除外 AspCompatfalse 显式设置的页的所有页面。
注意如果设置为 falseapartmentThreadingAspCompat 设置为 true 的目标页应用此修补程序后,您仍然可以在 STA 线程上运行 Session_Start 事件。

此修补程序适用于直接在会话状态中存储的 STA 对象。此修补程序还会为 STA 对象的嵌套如.net 对象存储在会话状态中的并且对 STA 对象的引用的一个级别深度。但,为 STA 对象的存储多个深入的级别,也不起作用此修补程序。

重要此修补程序包含两种类型的包: 在 Microsoft Windows 安装程序软件包和一个可选组件管理器包 (OCM)。如果您使用 Microsoft Windows Server 2003,您必须指定您需要在 Windows Server 2003 (OCM) 更新,因为 Windows Server 2003 文件保护监视.net Framework 1.1 文件。如果您使用不同于 Windows Server 2003 操作系统,您必须继续使用 Windows 安装程序包。

此修补程序的 OCM 版本是可用于以下语言:
  • 英语 (ENU)
  • 日语 (日文)
  • 德语 (DEU)
  • 法语 (FRN)
现在提供 Microsoft,受支持的修复程序,但它只用于解决本文所述的问题。仅将它应用于出现这一特定问题的系统。此修补程序可能还会接受进一步的测试。因此,如果此问题没有对您造成严重的影响,我们建议您等待包含此修复程序将下一个 Microsoft.net Framework 1.1 服务包。

要立即解决此问题,请与 Microsoft 产品支持服务以获取此修复程序。有关 Microsoft 产品支持服务电话号码和关于支持费用的信息的完整列表,请访问下面的 Microsoft 网站:
http://support.microsoft.com/contactus/?ws=support
注意 在特殊的情况中如果 Microsoft 支持专业人员确定某个特定更新才能解决您的问题,可能会被取消通常会导致支持电话的费用。将正常收取支持费用将应用于其他支持问题和不需要进行专门更新的问题。

此修补程序的英文版具有文件属性 (或更高版本) 下表中列出。其格式为协调通用时间 (UTC) 列出日期和时间对这些文件。当您查看文件信息时,将转换为本地时间。若要 UTC 与本地时间之间的时差使用控制面板中的日期和时间工具中的 时区 选项卡。
   Date         Time   Version       Size       File name
   ------------------------------------------------------------------------
   18-Sep-2003  05:18  1.1.4322.947    258,048  Aspnet_isapi.dll
   18-Sep-2003  05:18  1.1.4322.947     20,480  Aspnet_regiis.exe
   18-Sep-2003  05:18  1.1.4322.947     32,768  Aspnet_state.exe
   18-Sep-2003  05:18  1.1.4322.947     32,768  Aspnet_wp.exe
   16-May-2003  01:49                   33,522  Installpersistsqlstate.sql
   16-May-2003  01:49                   34,150  Installsqlstate.sql
   18-Sep-2003  05:09  1.1.4322.947     94,208  Perfcounter.dll
   19-Sep-2003  02:43  1.1.4322.947  1,216,512  System.dll
   19-Sep-2003  02:40  1.1.4322.947    323,584  System.runtime.remoting.dll
   19-Sep-2003  02:43  1.1.4322.947  1,253,376  System.web.dll
   19-Sep-2003  02:42  1.1.4322.947    819,200  System.web.mobile.dll
   19-Sep-2003  02:41  1.1.4322.947    569,344  System.web.services.dll
   19-Sep-2003  02:44  1.1.4322.947  1,335,296  System.xml.dll
   18-Sep-2003  05:13                   14,472  Webuivalidation.js

状态

Microsoft 已经确认这是本文"适用于"一节中列出的 Microsoft 产品中的问题。

更多信息

此修补程序包还包括辅助的修补程序。 如果为 true,设置 AspCompat,并且您设置为 null 的会话状态中存储的 STA 对象您在重新加载网页时可能会收到一条"NullReferenceException"错误消息。要重现该辅助问题,将粘贴下面的代码内
	Session["obj"] = new Object();

	Session["obj"] = null;
代码时在第一次访问此页,可以正常运行。 Page_Load 事件。但是,如果重新加载网页,从 Microsoft ASP.NET,您会收到一条"NullReferenceException"错误消息,您不能在当前会话中再次查看该页。

堆栈跟踪:
[NullReferenceException: Object reference not set to an instance of an object.]
System.Web.UnsafeNativeMethods.AspCompatOnPageStart(Object obj) +0
System.Web.Util.AspCompatApplicationStep.OnPageStartSessionObjects() +90
System.Web.UI.Page.ProcessRequestMain() +44
AspCompat 设置为 false 时,如果没有出现此问题。

重现行为的步骤

重新产生本文"症状"一节中出现的问题,请按照下列步骤操作:
  1. 使用 Microsoft Visual Basic.net 创建 Visual Basic ActiveX DLL 对象。

    注意如果您将组件标记为 无人参与执行 (UE),仍然出现此错误。
  2. DLL 类中创建两个函数,请执行以下操作:
    1. 创建一个函数,返回一个字符串。
    2. 创建带一个长的参数的函数并返回一个 LONG 值的。此函数执行一个循环,将编号从 1 添加到传递给函数的数值。
  3. 创建新的 Web 应用程序 项目具有两个.aspx 页 (Page1.aspx 和 Page2.aspx)。
  4. Session_Start 事件的在 Global.asax 文件中使用 CreateObject 创建在第 1 步中创建该对象的实例。
  5. Page1.aspx Page_Load 事件中调用该函数在从存储在会话状态中的对象的第 2 步中创建的函数之一。
  6. 在 $ Page1.aspx 中创建一个指向 Page2.aspx 的超链接。
  7. Page2.aspx Page_Load 事件中调用 Session.Abandon 方法。
  8. 使用应用程序中心测试 (活动) 来创建记录的查看 Page1.aspx,然后查看 Page2.aspx 运行的测试。
  9. 与 10 个用户运行测试。如果错误 0x8004e005 出现在事件查看器,请参阅。

    注意您可能需要增加重现该问题的用户数。

参考

有关更多的信息请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
243543信息: 在会话或应用程序存储 STA 对象
243815PRB: 存储在 $ 会话中的 STA COM 组件锁定会话下的单线程
817005FIX: 严重性能问题时您将会话状态绑定到 ASPCompat 模式中的线程

属性

文章编号: 827164 - 最后修改: 2014年2月26日 - 修订: 1.7
这篇文章中的信息适用于:
  • Microsoft .NET Framework 1.1
  • Microsoft Visual Studio .NET 2003 Enterprise Architect
  • Microsoft Visual Studio .NET 2003 Enterprise Developer
  • Microsoft Visual Studio .NET 2003 Academic Edition
  • Microsoft ASP.NET 1.1
关键字:?
kbnosurvey kbarchive kbmt kbhotfixserver kbqfe kberrmsg kbnetframe100presp3fix kbfix kbqfe kbcode kbbug KB827164 KbMtzh
机器翻译
注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。
点击这里察看该文章的英文版: 827164
Microsoft和/或其各供应商对于为任何目的而在本服务器上发布的文件及有关图形所含信息的适用性,不作任何声明。 所有该等文件及有关图形均"依样"提供,而不带任何性质的保证。Microsoft和/或其各供应商特此声明,对所有与该等信息有关的保证和条件不负任何责任,该等保证和条件包括关于适销性、符合特定用途、所有权和非侵权的所有默示保证和条件。在任何情况下,在由于使用或运行本服务器上的信息所引起的或与该等使用或运行有关的诉讼中,Microsoft和/或其各供应商就因丧失使用、数据或利润所导致的任何特别的、间接的、衍生性的损害或任何因使用而丧失所导致的之损害、数据或利润不负任何责任。

提供反馈

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com