Windows Server 2008 R2服务器内存使用率太高,但与任务管理器中进程占用内存和不一致

系统环境:
Windows Server 2008 R2 + Sql Server 2008 R2
 
问题描述:
Windows Server 2008 R2系统内存占用率过大,而在任务管理器中各进程内存占用总和都远不到此占用率。
相关现象:
1. 内存占用率90%以上
2. 任务管理器中全部进程内存和较低,远不到90%,有二十多G的内存误差
 
分析过程:
 
  1. 首先怀疑SQL Server内存占用,可是SQL Server设置了最大内存,且任务管理器中显示的内存占比并无达到很高,排除此缘由
  2. 用RamMap工具查看内存的详细使用状况,发现图元文件(Metafile)占用了二十多G的内存,应该与此有关
 
解决方法:利用RamMap的“清空系统工做集”功能,能够释放内存。
 
图元文件(Metafile):
     Metafile能够理解为系统缓存,Windows server 2008系统中,好比存在大量的文件拷贝等磁盘io操做,系统会自动将其缓存到内存中,这部分被占用的内存在任务管理器的中未体现出来的,因此用户会认为系统的内存占用异常。同时,MetaFile默认是没有限制的,因此系统会无限制占用内存。 可是对于Windows 2012以后,操做系统会自动限制系统缓存的上限从而避免物理内存的耗尽。
    看了图元文件的解释后,发现前两天一直在作转移文件的操做,几百G的大量小文件在不一样磁盘中转移,从而致使内存占用太高,符合此解释。至此,问题调查清楚。
 
以下, 是微软官方Blog中介绍修改注册表来限制动态缓存的方法:
Microsoft Windows Dynamic Cache的更新程序,用户能够下载后添加到服务中,经过修改注册表来限制动态缓存的最大值,好比设置上限为200M等,这样系统就能够把做为缓存使用的内存设置了上限值。
具体设置步骤以下:
1. 解压后根据不一样系统版本中对应的DynCache.exe文件复制到C:\windows\system32中。
2. 以管理员身份打开命令提示符,执行以下命令添加服务:
      sc create DynCache binPath= %SystemRoot%\System32\DynCache.exe start= auto type= own DisplayName= "Dynamic Cache Service"
3. 回到DynCache文件夹,找到DynCache.reg的注册表文件导入。
4. 打开注册表,找到HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\DynCache\Parameters
5. 右侧找到MaxSystemCacheMBytes,双击它,这里咱们选择“十进制”,在数值里输入要限制最大的缓存数(单位是MB),输入800就是限制缓存最大为800MB,输入0为不限制。
6. 到服务中启动DynCache服务。
注:下载的dyncache解压出来是有多几个版本可选的,请选择retail amd64的版本,不要选择ia64(ia64表示安腾的64位处理器版本)。
相关文章
相关标签/搜索