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 studio中SQL Server属性的内存部分下找到此设置: 查看Brent Ozar’s SQL Server deployment checklist in part ii中的内存最佳实践,了解有关此内容的更多详细信息. 由于最近这种情况开始发生,我猜是有人通过安装或运行另一个软件来与SQL服务器创建内存竞争. 最后,如果您想查看SQL Server实际用于缓冲池的内存量,请查看SQL Server内存管理器:Total Server Memory perfmon计数器.这是缓冲池使用的内存量(而不是总服务器内存). Taskman不会显示这个记忆. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- windows-firewall – 由Windows防火墙阻止的Teamviewer VPN
- Windows7的光标移动很慢
- 在Windows上用Xerces 3.0.1和C编写XML
- 限制.net文本框中的行数
- 使用DLL与PHP for Dummies
- windows-server-2008-r2 – 会影响复制速度的服务器操作系统
- batch-file – 使用xcopy进行并行复制
- Windows – Win 2008使用PDC IP加入域,但没有AD的域名
- windows – 增加“运行MRU”列表中的项目数
- Windows shell中的“Bootstrap”python脚本,没有.py / .pyw