SQLServer占用服务器内存过高,更改这个设置就能降低内存使用率

SQLServer占用服务器内存过高,更改这个设置就能降低内存使用率是 4 核 8G 的 只装了 4 个应用程序 其中就有 SQL SERVER2012 而且使用频率也不高 怎么会提示我内存使用率过高 难道是中毒了

欢迎大家来到IT世界,在知识的湖畔探索吧!

前两天我的服务器突然告警提示我的内存占用过高,使用率高达94.3%。当时我就有点纳闷了,服务器配置

SQLServer占用服务器内存过高,更改这个设置就能降低内存使用率

互联网服务器



欢迎大家来到IT世界,在知识的湖畔探索吧!

是4核8G的,只装了4个应用程序,其中就有SQL SERVER2012,而且使用频率也不高,怎么会提示我内存使用率过高,难道是中毒了?在紧急排查服务器进程后发现是SQL SERVER Windows NT占用内存过高,仅这一个程序就占用50%的内存。

原来SQL Server对服务器内存的使用策略是用多少内存就占用多少内存,只用在服务器内存不足时,才会释放一点占用的内存,所以SQL Server 服务器内存往往会占用很高。我们可以通过DBCC MemoryStatus来查看内存状态。

SQL SERVER运行时会执行两种缓存:

1. 数据缓存:执行个查询语句,SQL SERVER会将相关的数据页(SQL SERVER操作的数据都是以页为单位的)加载到内存中来, 下一次如果再次请求此页的数据的时候,就无需读取磁盘了,大大提高了速度。

2.执行命令缓存:在执行存储过程,自定函数时,SQL SERVER需要先二进制编译再运行,编译后的结果也会缓存起来, 再次调用时就无需再次编译。

可以调用以下几个DBCC管理命令来清理这些缓存:

DBCC FREEPROCCACHE --清除存储过程相关的缓存 DBCC FREESESSIONCACHE --会话缓存 DBCC FREESYSTEMCACHE('All') --系统缓存 DBCC DROPCLEANBUFFERS --所有缓存

欢迎大家来到IT世界,在知识的湖畔探索吧!

但是,这几个命令虽然会清除掉现有缓存,为新的缓存腾地方,但是Sql server并不会因此释放掉已经占用的内存。SQL SERVER并没有提供任何命令允许我们释放不用到的内存。因此我们只能通过动态调整SQL SERVER可用的物理内存设置来强迫它释放内存。

解决SQLSERVER内存占用过高的方法:

1、清除所有缓存  DBCC DROPLEANBUFFERS

2、调整SQLSERVER可使用的最大服务器内存。

  在SQL管理器,右击实例名称

SQLServer占用服务器内存过高,更改这个设置就能降低内存使用率

右击实例名称选择属性

  在属性实例属性里面找到内存选项

SQLServer占用服务器内存过高,更改这个设置就能降低内存使用率

最大内存建议不超过系统内存的1/2

把最大内存改成合适的内存,确定后内存就会被强制释放,然后重启实例。再看看任务管理器,内存使用率就降下来啦。

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://itzsg.com/115964.html

(0)
上一篇 21分钟前
下一篇 8分钟前

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们YX

mu99908888

在线咨询: 微信交谈

邮件:itzsgw@126.com

工作时间:时刻准备着!

关注微信