sqlserver2008r2 服务自动停止_Windows Server 2008 R2服务器内存使用率过高,但与任务管理器中进程占用内存和不一致..._weixin_39917894的博客-CSDN博客

来源: sqlserver2008r2 服务自动停止_Windows Server 2008 R2服务器内存使用率过高,但与任务管理器中进程占用内存和不一致…_weixin_39917894的博客-CSDN博客

系统环境:
Windows Server 2008 R2 + SQL Server 2008 R2

问题描述:
Windows Server 2008 R2系统内存占用率过大,而在任务管理器中各进程内存占用总和都远不到此占用率。
相关现象:

内存占用率90%以上

任务管理器中所有进程内存相加较低,远不到90%,有二十多G的内存偏差

分析过程:

首先怀疑SQL Server内存占用,但是SQL Server设置了最大内存,且任务管理器中显示的内存占比并没有达到很高,排除此原因
用RamMap工具查看内存的详细使用情况,发现图元文件(Metafile)占用了二十多G的内存,应该与此有关

解决方法:利用RamMap的“清空系统工作集”功能,可以释放内存。

图元文件(Metafile):
Metafile可以理解为系统缓存,Windows server 2008系统中,比如存在大量的文件拷贝等磁盘io操作,系统会自动将其缓存到内存中,这部分被占用的内存在任务管理器的中未体现出来的,所以用户会认为系统的内存占用异常。同时,MetaFile默认是没有限制的,所以系统会无限制占用内存。但是对于Windows 2012之后,操作系统会自动限制系统缓存的上限从而避免物理内存的耗尽。
看了图元文件的解释后,发现前两天一直在做转移文件的操作,几百G的大量小文件在不同磁盘中转移,从而导致内存占用过高,符合此解释。至此,问题调查清楚。

如下, 是微软官方Blog中介绍修改注册表来限制动态缓存的方法:
Microsoft Windows Dynamic Cache的更新程序,用户可以下载后添加到服务中,通过修改注册表来限制动态缓存的最大值,比如设置上限为200M等,这样系统就可以把作为缓存使用的内存设置了上限值。
下载地址: http://www.microsoft.com/en-us/download/details.aspx?id=9258
具体设置步骤如下:

解压后根据不同系统版本中对应的DynCache.exe文件复制到C:\windows\system32中。

以管理员身份打开命令提示符,执行如下命令添加服务:
sc create DynCache binPath= %SystemRoot%\System32\DynCache.exe start= auto type= own DisplayName= “Dynamic Cache Service”

回到DynCache文件夹,找到DynCache.reg的注册表文件导入。

打开注册表,找到HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\DynCache\Parameters

右侧找到MaxSystemCacheMBytes,双击它,这里我们选择“十进制”,在数值里输入要限制最大的缓存数(单位是MB),输入800就是限制缓存最大为800MB,输入0为不限制。

到服务中启动DynCache服务。
注:下载的dyncache解压出来是有多几个版本可选的,请选择retail amd64的版本,不要选择ia64(ia64表示安腾的64位处理器版本)。

转载于:https://www.cnblogs.com/Juning/p/11076632.html
————————————————
版权声明:本文为CSDN博主「weixin_39917894」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_39917894/article/details/111331467

赞(0) 打赏
分享到: 更多 (0)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏