ASP .NET Web 应用程序内存泄漏 - 探查器显示大量字符串

ASP .NET web application memory leaks - profiler shows a lot of strings

我的 Web 应用程序经常遇到 IIS 对分配给应用程序池的虚拟内存设置的限制。这会导致 IIS 停止应用程序。

我一直在尝试使用 .NET 内存分析器来识别我的应用程序中可能存在的内存泄漏,到目前为止,GC 后保留的最大内存量似乎是字符串。即使访问一页,内存使用量也会增长很多。

当我查看存储的字符串时,我发现重复的字符串,例如 SqlDataSource.SelectCommand

中使用的 SQL 查询

我的网站包含一个母版页,其中我有一些用户控件。在其中一个用户控件中,我使用了一个 SqlDataSource,它从数据库中执行一个简单的 select,如下所示:

<asp:SqlDataSource DataSourceMode="DataSet" CacheDuration="100" ID="myDataSource"
    runat="server" ProviderName="System.Data.Odbc" ConnectionString="<%$ ConnectionStrings:mysql %>"></asp:SqlDataSource>

在控件的 Page_Load 我有:

myDataSource.SelectCommand =
            "SELECT * from table limit 0,10";

我发现同一个字符串在内存中重复了数百次(可能每次访问页面时)。

我错过了什么吗?我必须手动处理数据源吗?

谢谢

更新:

原来大量的字符串(包括 SQL 查询)被保存在内存中,因为我有几个自定义用户控件显然默认使用 EnableViewState="true"

为这些控件设置 EnableViewState="false" 后(我不需要它)并且字符串不再填满内存

更新 1:

在生产中设置 EnableViewState="false" 后,应用程序池不再达到虚拟内存限制,因此问题已解决!

原来大量的字符串(包括 SQL 查询)被保存在内存中,因为我有几个自定义用户控件显然默认使用 EnableViewState="true"

为这些控件设置 EnableViewState="false" 后(我不需要它)并且字符串不再填满内存

更新 1:

在生产中设置 EnableViewState="false" 后,应用程序池不再达到虚拟内存限制,因此问题已解决!

本文深入解释了正在发生的事情:https://blogs.msdn.microsoft.com/tess/2008/09/09/asp-net-memory-identifying-pages-with-high-viewstate/ (感谢 Lex Li)