加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Windows > 正文

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

发布时间:2020-12-14 00:14:29 所属栏目:Windows 来源:网络整理
导读:我有一台服务器报告8 GB的ram用完了99%.重新启动Sql Server时,它会降低到大约5%的使用率,但在大约2小时内逐渐恢复到99%. 当我查看sqlserver进程时,它报告为仅使用100k ram,并且通常永远不会上升或低于该数字.事实上,如果我将我的TaskManager中的所有进程
我有一台服务器报告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不会显示这个记忆.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读