- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
问题出在内存管理上,因为我一直收到“内存不足异常”。
以下是我们面临问题的方案:
请注意:
1.该站点/应用程序是使用ASP.Net开发的,并按照以下规范上传到服务器上:
-Windows Server 2008(R2)标准
-Intel Xeon L5520@2.27GHz 2.27GHz
-内存= 8GB
-系统类型= 64位
该应用程序是基于事件管理的Web应用程序,其中的要求包括在Sessions等中保存大量数据(在相关的情况下进行提及)
应用程序/站点可以正常运行,直到我们:
直接在服务器上编辑文件
从存储库更新文件
复制/粘贴文件(我们通常不使用此技术来编辑代码)
请注意,以上所有条件仅在网站访问量很高(即,
当访问量较低时,不会产生“内存不足”的问题/错误
的细节:
系统属性>高级>性能设置>高级选项卡
所有驱动器的页面文件总大小:16362 MB
在web.config中
有什么方法可以将这个问题调试到核心并找到解决方案。您能否提供链接/帮助,以便我们进一步调查此问题?
最好的祝福,
法鲁克
最佳答案
内存不足异常对于看到定期事务激增同时将大量数据保留在内存中的应用程序很常见。但是,此问题确实取决于您的应用程序和体系结构。以下是一些提示:
硬件-您拥有Xeon 5500(英特尔Nehalem芯片)。这些非常擅长处理内存。你在这里应该很好。
操作系统-Windows Server 2008 R2-作为操作系统,该系统将为您处理足够多的内存(您在这里很好,请参见功能链接:Memory Limits for Windows)
物理内存-您是否说服务器上有8 GB?请注意,您的应用程序允许使用16 GB。有一个问题。如果您的应用请求的内存大于实际可用内存,则会看到错误。但这不是您唯一关心的问题...
CLR / GC限制-您的应用程序的“分页文件大小”为16+ GB。这可能是您的问题。
GC是您遇到的问题的核心。就其原因而言,这与Java和JVM在应用程序超过2-4 GB时出现问题的原因相同。这需要查看GC的实际过程。
您有“旧一代”和“年轻一代”垃圾收集流程。当您运行应用程序时,CLR会尝试使您的内存空间井井有条。这些进程会在发生GC标记和交换进程时强制所有线程暂停(阶段更改)。这里的问题是,取决于代码的编写方式和长时间保留的内存量,您可能会遇到内存问题。
每当您按下运行时环境超过4 GB阈值时,您都会看到收集时间呈指数增长。当您碰到“停止世界”的停顿(旧的GC将清除所有内容)时,CLR必须遍历整个堆并释放内存。根据您的应用,16 GB可能会给您带来更多物理内存问题(Windows Server 2008 R2-Enterprise或DataCenter可以支持2 TB)。即使您为它提供了更多的物理内存,也可能在完整GC命中时看到很长的收集时间。
理想情况下,我将执行以下操作:
获得更多的物理内存(您永远不希望将600MB的总物理内存分配给应用程序,以避免出现内存不足错误,但是缓冲区的确取决于您的负载和应用程序处理它的能力...您可能想要一个更大的安全网才算安全)。
拥有物理内存后,需要在对应用程序施加压力的同时运行GC日志。这将使您有一个想法,即在考虑到堆大小(内存)时,性能会呈指数级下降以及应用程序可以支持的级别。您可能想找到一种将16GB页面缩小到较小尺寸的方法。我确实知道使用.Net 4.0,Microsoft对GC流程进行了一些实质性的改进,包括允许后台线程维护GC。从理论上讲,这应该使您能够支持更大的堆……但是没有什么比在应用程序上进行真正的测试更好的了。查看此链接以获取更多信息:
Garbage Collection Performance (Asp.net 4.0)-另外,由于我对链接的限制。导航到“基础知识”页面,以获取有关ASP.Net 4.0的新GC功能的出色解释。
(http://msdn.microsoft.com/zh-cn/library/ee787088.aspx#concurrent_garbage_collection)
希望这可以帮助!
PS-使用较少硬件的任何人都需要了解GC线程的ASP.NET使用。如果您正在开发诸如Core Duo之类的产品,则必须考虑将50%的计算能力用于GC优化。这意味着必须考虑硬件(内核数)。如果您拥有的资源超过所需,那么此过程从理论上应有助于提高性能。如果您受内核限制,则可以使用更好的硬件,或者使用旧版本的ASP.Net,或者考虑关闭此功能(如果可能)。其次,如果需要考虑延迟,则使用“超线程”也确实会对性能产生影响。您始终可以在“物理”内核上获得更好的性能……但是对于99.9%的应用程序来说,这并不是问题。
关于asp.net - 内存不足异常-ASP.NET-IIS 7,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7388649/
所以我正在为考试复习,并在 SQL 河(或荒地)中撞到了一块大石头 我制作了以下表格并插入了以下数据: create table Permissions ( fileName VARCHAR(
我有一个使用 maxWidth 定义的 jqueryui 对话框。 $("#myDialog").dialog({ autoOpen: false, width: 'a
注意:我遗漏了不相关的代码 所以我目前正在研究 CCC 1996 P1,这个问题的全部目的是能够计算一个整数输入是完美数、不足数还是充数。我上面列出的代码可以工作,但是我认为它太慢了。该代码会迭代每个
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我正在使用 Go 和 Redis 开发 API。问题是RAM使用不足,我找不到问题的根源。 TL;DR 版本 有数百/数千个哈希对象。每个 1 KB 的对象(键+值)占用大约 0.5 MB 的 RAM
在我的 GCE Kubernetes 集群上,我无法再创建 pod。 Warning FailedScheduling pod (www.caveconditions.com-f1be467e3
当我尝试在EKS Fargate群集上安装指标服务器时,它抛出错误: 0/4 nodes are available: 4 Insufficient pods. 按照以下说明从此处安装指标服务器:ht
遍布this document Apple 提到 iOS 在某些情况下会终止应用程序,最常见的原因似乎是释放一些 RAM。这会导致未实现状态恢复的应用程序出现问题——用户正在处理和暂时离开的一些内容可
尝试处理一个10分钟的音频文件时出现以下错误。我刚刚开始使用Google Cloud产品,所以我是唯一访问此资源的人。我怎么可能超出配额?配额设置为其默认值,我认为我没有任何限制。还有其他原因吗? 我
R 语言让我感到困惑。实体有模式和类,但即使这样也不足以完全描述实体。 这个answer说 In R every 'object' has a mode and a class. 所以我做了这些实验:
我在 west-1 有一个 Openshift v3 项目。在其中,我有一个运行良好的应用程序,但在 GitHub 提交代码中非常下游的内容后,该应用程序停止工作。问题在于制作 pod: No nod
我在 west-1 有一个 Openshift v3 项目。在其中,我有一个运行良好的应用程序,但在 GitHub 提交代码中非常下游的内容后,该应用程序停止工作。问题在于制作 pod: No nod
在 how-do-i-access-the-stackoverflow-api-from-mathematica我概述了如何使用 SO API 让 Mathematica 制作一些有趣的顶级回答者声誉
所以在 GKE 上,我有一个 Node.js app,每个 pod 使用大约:CPU(cores): 5m, MEMORY: 100Mi 但是我只能为每个 Node 部署 1 个 pod。我使用的是
我正在使用 async.eachOfSeries 超过 300 个数组并请求一些 GA api,它工作正常但有时我会收到错误.. UnhandledPromiseRejectionWarning:错误
我正在尝试在 AWS ec2 上托管的 kubernetes 集群上使用 mr3 设置配置单元。当我运行命令 run-hive.sh 时,Hive 服务器启动,并且 master-DAg 被初始化,但
创建订阅时有时会出现以下错误: Insufficient tokens for quota 'administrator' and limit 'CLIENT_PROJECT-100s' of ser
我是一名优秀的程序员,十分优秀!