我们看到很多虚拟内存碎片和内存不足错误,然后它达到了3GB的限制.
在web.config中编译调试设置为true但是我从每个人那里得到不同的答案,调试设置为true会导致每个aspx编译成ram的随机区域,从而破坏ram并最终导致内存不足问题吗?
M4N*_*M4N 77
Scott Guthrie(ASP.NET开发团队经理)有一篇有趣的帖子.
你不应该离开debug ="true"的最重要的一点是:
他还提到了debug="true"
machine.config 中的flag >,它允许全局覆盖在机器上运行的所有应用程序的debug ="true"标志(例如在生产服务器上).
更新:部署Web应用程序<deployment retail=”true”/
仍然很糟糕,您可以阅读Scott Hanselman最近的博客文章:
这就是为什么debug ="true"是坏的.说真的,我们不是在开玩笑.
一个重要的注意事项:与有时认为的相反,在元素中设置retail ="true"并不是调试="true"的直接解毒剂!
Guf*_*ffa 13
除非您确实需要调试应用程序,否则应在web.config中将debug标志设置为false.
在调试模式下运行可以在一定程度上增加内存使用量,但它可能不像你所说的那样严重.但是,您应该将其设置为false以消除它所具有的效果,并查看是否可以注意到任何改进.
在调试模式下运行时,垃圾回收的工作方式不同.变量的生命周期从它的实际使用扩展到变量的范围(能够在调试器中显示值).这使得一些对象在被垃圾收集之前活得更长.
编译器在调试模式下编译时不会优化代码,并且还会nop
添加一些额外的指令,以便每个代码行至少有一条指令可以放置断点.
在调试模式下抛出异常需要相当长的时间.(但是,通常代码不应该经常抛出异常.)
AFAIK“debug = true”不会导致您提到的情况。
我在使用动态创建图像的 ASP.NET 应用程序时遇到了同样的问题。
所以我认为你有一个未处置资源的问题。
如果您将带有代码隐藏文件的 aspx 文件部署到服务器。当请求到达 aspx 时,它将被编译一次。然后它将被存储到缓存中,直到文件发生更改。
归档时间: |
|
查看次数: |
44790 次 |
最近记录: |