我有一台服务器报告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 studio中sql Server属性的内存部分下找到此设置:
查看Brent Ozar’s SQL Server deployment checklist in part ii中的内存最佳实践,了解有关此内容的更多详细信息.
由于最近这种情况开始发生,我猜是有人通过安装或运行另一个软件来与sql服务器创建内存竞争.
最后,如果您想查看sql Server实际用于缓冲池的内存量,请查看sql Server内存管理器:Total Server Memory perfmon计数器.这是缓冲池使用的内存量(而不是总服务器内存). Taskman不会显示这个记忆.