限制IIS站点的内存,避免级联影响

背景

代码写的有问题,会很容易出现内存泄露的问题。

应用如果是部署在docker容器里面的,可以限制这个应用的内存。

那么,如果是传统的.NET Framework应用,部署在IIS上面呢?

老黄曾经遇到过在一台服务器上面,IIS部署了五六个站点。

其中一个站点,占用了 5、6G 的内存,然而服务器只有8G的内存,甚至胡时候会把其他一两个站点的应用程序池逼停了。

想想就可怕,资源的隔离没有做好,导致其他应用也受到了影响。

其实对IIS来说,还是可以对站点做限制的。

如何处理

应用程序池中,有两个关于内存的配置:

  1. 虚拟内存限制(KB)
  2. 专用内存限制(KB)

虚拟内存限制指的是,工作进程可以使用的最大虚拟内存量,超过这个内存量就会导致应用程序池回收。默认值是0,表示不限制。

专用内存限制指的是,工作进程可以使用的最大专用内存量,超过这个内存量就会导致应用程序池回收。默认值是0,表示不限制。

正常来说,我们常说的,应用占用了多少内存其实说的就是这个专用内存。

我们打开的任务管理器,上面看到的内存,也是专用工作集。

所以针对这上面说的情况,我们只要限制这个程序池的专用内存限制即可。

好比说限制为100MB,就把专用内存限制填102400。

当应用的内存达到这个限制的时候,它会重新拉起一个进程,然后把老的进程kill掉。

可以通过事件查看器捕获到对应的事件。

这样就可以在一定程度上缓解多个应用之间互相影响。

当然最终的解决办法还是要把内存泄露的bug处理掉。

posted @ 2021-01-24 21:38  Catcher8  阅读(1593)  评论(0编辑  收藏  举报