windows-server-2008 – SQL Server达到99%内存使用率时性能不佳

我有一台服务器报告8 GB的ram用完了99%.重新启动sql Server时,它会降低到大约5%的使用率,但在大约2小时内逐渐恢复到99%.

当我查看sqlserver进程时,它报告为仅使用100k ram,并且通常永远不会上升或低于该数字.事实上,如果我将我的TaskManager中的所有进程加起来,它几乎没有触及我的总体可用表面(但是,在显示“所有进程”时,TaskManager仍显示99%的内存使用率).

似乎sql Server发生了巨大的内存泄漏,但它没有报告它.服务器已经运行了近两年,这在过去的3-4周内才刚刚开始显现.

有人看过这个或对问题有任何见解吗?

编辑

当服务器达到99%时,性能下降.对服务器,应用程序等的所有查询都会被抓取.重新启动服务会让事情再次发生变化,直到2小时过去,服务器再次达到99%.

sql服务器将尽可能多地缓存数据 – 正如其他人所说的那样好.它缓存的这个数据称为缓冲区缓存 – 但是你需要限制它.

所以你需要做的就是限制缓冲区缓存的大小.经验法则是(Total_RAM – (2GB或10%(以较大者为准))=最大缓冲区缓存.如果不限制此缓存的大小,则服务器可能会因操作系统和sql开始竞争而开始遇到内存压力对于内存.您可以在management studiosql Server属性的内存部分下找到此设置:

查看Brent Ozar’s SQL Server deployment checklist in part ii中的内存最佳实践,了解有关此内容的更多详细信息.

由于最近这种情况开始发生,我猜是有人通过安装或运行另一个软件来与sql服务器创建内存竞争.

最后,如果您想查看sql Server实际用于缓冲池的内存量,请查看sql Server内存管理器:Total Server Memory perfmon计数器.这是缓冲池使用的内存量(而不是总服务器内存). Taskman不会显示这个记忆.

相关文章

Windows注册表操作基础代码 Windows下对注册表进行操作使用的...
黑客常用WinAPI函数整理之前的博客写了很多关于Windows编程的...
一个简单的Windows Socket可复用框架说起网络编程,无非是建...
Windows文件操作基础代码 Windows下对文件进行操作使用的一段...
Winpcap基础代码 使用Winpcap进行网络数据的截获和发送都需要...
使用vbs脚本进行批量编码转换 最近需要使用SourceInsight查看...