zoukankan      html  css  js  c++  java
  • SQL SERVER占用服务器内存过高的解决方案

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
    本文链接:https://blog.csdn.net/xiaogang107/article/details/89878583

    SQL Server对服务器内存的使用策略是用多少内存就占用多少内存,只用在服务器内存不足时,才会释放一点占用的内存,所以SQL Server 服务器内存往往会占用很高。

    这些内存一般都是SQL Server运行时候用作缓存的:

    1. 数据缓存:执行个查询语句,SQL Server会将相关的数据页(SQL Server操作的数据都是以页为单位的)加载到内存中来, 下一次如果再次请求此页的数据的时候,就无需读取磁盘了,大大提高了速度。
    2.执行命令缓存:在执行存储过程,自定函数时,SQL Server需要先二进制编译再运行,编译后的结果也会缓存起来, 再次调用时就无需再次编译。

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

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

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

     

    解决SQL Server占用内存过高的具体步骤:

    1、清除所有缓存
    DBCC DROPCLEANBUFFERS

     
    2、调整可使用物理内存

     


    将最大服务器内存改成4G,确定后内存就会被强制释放,然后把最大服务器内存改成合适的值。

    参考链接:https://blog.csdn.net/shenwb110/article/details/74987577
    ————————————————
    版权声明:本文为CSDN博主「^_^laoz^_^」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/xiaogang107/article/details/89878583

  • 相关阅读:
    centos8.0 安装 jenkins
    No match for argument: mysql-community-server Error: Unable to find a match: mysql-community-server
    Navicat 远程连接 centos8.0
    centos8.0 安装 mysql
    -bash: java-version: command not found
    centos8.0 安装 JDK1.8
    [Err] 1062
    android之Fragment基础详解(一)
    Android之RecyclerView(一)
    Android之ProgressBar
  • 原文地址:https://www.cnblogs.com/purple5252/p/11547880.html
Copyright © 2011-2022 走看看