我的编程空间,编程开发者的网络收藏夹
学习永远不晚

30秒,2种方法解决SQL Server的内存管理问题

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

30秒,2种方法解决SQL Server的内存管理问题

30秒,2种方法解决SQL Server的内存管理问题

今天和大家聊一聊SQL server的内存管理,说之前我们需要先提出一个问题,SQL Server到底是如何使用内存的?弄清楚如何使用之后,才能谈如何管理。

简单说,SQL Server 数据库的内存使用原则是有多少内存就会占用多少内存,不会自动释放内存。原因是它的存储引擎本身是一个Windows下的进程,所以在使用内存时和其它Windows进程是一样的,都要向Windows申请内存,申请到内存之后,SQL Server的内存使用可以粗略地分为两个部分:一是缓冲池内存,被数据页和空闲页占用;二是非缓冲内存,被线程、DLL、链接服务器等占用。其中缓冲池内存占大头。

这样会有什么问题呢?打个比方,如在执行一条结果集很大的 sql 时,数据查询取出后,会一直占用内存,直到机器内存被占满(并不会撑爆,因为可以通过图去限制最大内存,一般占满后仍然比服务器机器内存稍小),在重启数据库服务前,SQL Server不会主动释放该内存,也没有任何办法可人为释放,一直占用到 max server memory 的设定值,因此查看 SQL Server的内存基本使用率相对较高(80%以上)。

那怎么解决呢?最直接的办法是:人为修改最大可占用物理内存进行限制。

方法一:

缓冲池所占内存是通过下图1最大服务器内存和最小服务器内存来设置的,因此sqlservr.exe所占的内存(如图2)有可能会大于图1中所设置的最大内存。管理员用户登录数据库客户端(Microsoft SQL Server Management Studio),在实例名(树形菜单根节点,显示登录名那栏)上右键,选择属性-->内存,设置“最大服务器内存”即可根据实际情况调整内存(单位为MB),如调整到当前总的服务器内存的 70%左右使用率。

图1 SQL Server可控制内存选项

图2 SQL Server 进程内存使用情况

方法二:

如果使用的是华为云RDS SQL Server ,那解决方法就更加简单了,只需要到控制台实例管理中修改最大内存(max server memory)参数值即可,且修改完该参数不需要重启数据库,不得不说云数据库使用起来更加便捷清晰,更多华为云RDS SQL Server的使用可参考 官方文档:https://support.huaweicloud.com/rds/index.html

 

点击关注,第一时间了解华为云新鲜技术~

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

30秒,2种方法解决SQL Server的内存管理问题

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

30秒,2种方法解决SQL Server的内存管理问题

今天和大家聊一聊SQL server的内存管理,说之前我们需要先提出一个问题,SQL Server到底是如何使用内存的?弄清楚如何使用之后,才能谈如何管理。 简单说,SQL Server 数据库的内存使用原则是有多少内存就会占用多少内存,不会自动释放内存。原因
30秒,2种方法解决SQL Server的内存管理问题
2018-10-29

C#中常见的内存管理问题及解决方法

C#中常见的内存管理问题及解决方法,需要具体代码示例在C#开发中,内存管理是一个重要的问题,不正确的内存管理可能会导致内存泄漏和性能问题。本文将向读者介绍C#中常见的内存管理问题,并提供解决方法,并给出具体的代码示例。希望能帮助读者更好地理
2023-10-22

C++中常见的内存管理问题解决方案

C++中常见的内存管理问题解决方案引言:内存管理是开发过程中的重要问题之一。在C++中,程序员需要负责分配和释放内存,以确保程序的稳定性和性能。然而,由于C++没有垃圾回收机制,内存管理问题常常成为程序员头疼的问题。本文将介绍C++中常见的
2023-10-22

C++技术开发中的内存管理问题及解决方法

C++技术开发中的内存管理问题及解决方法在C++开发中,内存管理是一个关键的问题。不正确的内存管理可能导致内存泄漏、野指针访问、内存溢出等严重的后果。本文将探讨一些常见的内存管理问题,并提供相应的解决方法和示例代码。内存泄漏内存泄漏指的是程
2023-10-22

C++中常见的内存管理问题的解决方案

C++中常见的内存管理问题的解决方案引言:在C++语言中,内存管理是一个非常重要且常见的问题。由于C++没有自动内存管理机制,开发者需要负责手动分配和释放内存。然而,这往往容易引发内存泄漏、内存溢出和野指针等问题。本文将介绍一些常见的内存管
2023-10-22

Python开发中遇到的内存管理问题及解决方案

Python开发中遇到的内存管理问题及解决方案摘要:在Python开发过程中,内存管理是一个重要的问题。本文将讨论一些常见的内存管理问题,并介绍相应的解决方案,包括引用计数、垃圾回收机制、内存分配、内存泄漏等。并提供了具体的代码示例来帮助读
2023-10-22

编程热搜

目录