SQL Server 内存和Paging

VAS:Virtual Address Space,是App能够申请访问的最大地址空间。

Reserved Memory:申请将VAS的一段地址空间Reserve,对Reserved的部分 Memory Page 进行Commit,那么Committed Memory 将获得Physical Memory。

Workset 是 Committed Memory的一部分,是Process在运行时使用的物理内存。

Page Fault:App访问一个处于Reserved Memory的Page,但是该page不存在于Workset,就会发生一次Page Fault。如果目标Page 存在于Page File(Disk),那么OS会进行一次IO,将目标Page从Disk读取到Workset中,称作Hard falut;如果目标Page存在于committed memory,那么只需要将目标Page重定向到Workset中,称作Soft Fault,Soft Fault对性能的影响微乎其微。

手绘一张图:SQL Server 是预先 Reserved 一块大的内存,在使用的时候,一块一块的提交Commit,而committed Memory 在访问时转换为物理中,可以理解,committed memory 是SQL Server使用的物理内存,能够向物理内存Page中写入数据和读取数据。

当出现内存压力时,需要关注SQL Server的Committed Memroy, Workset 和 HardFault。

Committed memory是将reserverd memory(virtual memory) 转换为 physical memory,是app真正使用的物理内存。

Page File 是文件缓存,OS用于临时存储内存中Page的Disk File。如果内存不足,那么 OS会将部分page 存储在Page File中,产生一次Disk File的Write 操作;如果App需要用到Page File中的Page,那么OS会将Page File的目标Page读取到内存中,产生一次Disk File的Read操作。如果Page File的%Uage高,说明App实际需要的内存和committed memory的差距较大,App需要频繁的将Page存储到Disk File中。

Page Fault:Hard Page Fault是指OS将目标Page从Page File读取到物理内存中,由于会产生一次Disk IO,对App的性能影响较大。Soft Page Fault 是指目标Page存在于物理内存中,只是需要重定向到Workset中,对App的性能影响微乎其微。

对于一个性能良好的SQL Server 系统来说,Hard Page Fault 应该保持在一个较小的数值,Disk 的 Paging 动作越少越好。系统存在足够的内存,会使目标Page能够长时间的驻留在物理内存中,而不需要频繁的进行Disk的Paging动作。

如果内存不足,OS和 SQL Server 会在物理内存和文件缓存之间做大量的Paging 动作(Page的换进和换出),这会导致大量的Disk IO,使得Disk IO比较繁忙;OS要做Paging 动作,所带来的Disk IO的动作必须运行在核心态下,所以会核心态的CPU时间会升高,而用户态的CPU时间反而不会很高。一般情况下,用户态的CPU时间很高说明SQL Server 正在全力工作。

时间: 2024-10-19 06:04:22

SQL Server 内存和Paging的相关文章

SQL SERVER 内存分配及常见内存问题(1)——简介

原文:SQL SERVER 内存分配及常见内存问题(1)--简介 一.问题: 1.SQL Server 所占用内存数量从启动以后就不断地增加: 首先,作为成熟的产品,内存溢出的机会微乎其微.对此要了解SQL SERVER与windows是如何协调.共享内存.并且SQL SERVER的内部对内存的管理机制. 2.在Windows 2003以上版本运行的SQL Server,内存使用量突然急剧下降: 内存是Sqlserver的生命线.在errorlog中,出现一下情况:       这类问题往往不是

Sql Server 内存相关计数器以及内存压力诊断

在数据库服务器中,内存是数据库对外提供服务最重要的资源之一, 不仅仅是Sql Server,包括其他数据库,比如Oracle,MySQL等,都是一类非常喜欢内存的应用. 在Sql Server服务器中,最理想的情况是Sql Server把所有所需的数据全部缓存到内存中,但是这往往也是不现实的,因为数据往往总是大于可用的物理内存 可以说内存是否存在压力能够直接决定数据库能否高效运行,同时,如果内存出现压力,同时也会影响到CPU的使用和存储性能,可以说是一损俱损,具有连带性. 那么,如何识别内存是否

SQL SERVER 内存学习系列(一)

最近帮客户解决发布订阅的问题时,突然遇到这样一个问题发布订阅中报下面的错误,另外执行alter table 操作时也会报错 : 问题很奇怪发布订阅和CLR有什么关系?memtoleave内存是个啥?回忆学习体系架构的时候,确实看到过memtoleave内存,但是是什么已经完全想不起来了,所以拿起书本回味一下学习的快感... ---------------转载请注明出处------------http://www.cnblogs.com/double-K/p/5049417.html-------

SQL Server 内存中OLTP内部机制概述(一)

----------------------------我是分割线------------------------------- 本文翻译自微软白皮书<SQL Server In-Memory OLTP Internals Overview>:http://technet.microsoft.com/en-us/library/dn720242.aspx ----------------------------我是分割线------------------------------- SQL S

(译)内存沉思:多个名称相关的神秘的SQL Server内存消耗者。

原文:(译)内存沉思:多个名称相关的神秘的SQL Server内存消耗者. 原文出处:https://blogs.msdn.microsoft.com/sqlmeditation/2013/01/01/memory-meditation-the-mysterious-sql-server-memory-consumer-with-many-names/ 对于多个不同名称的内存消费者 你曾经是否想知道内存授予是什么(Memory grants )?什么是查询执行的保留(预定)内存(QE Reser

学习 Sql Server 内存管理之术语理解

在学习sql server 内存管理时,看到一些term:memory node,memory clerk,memory object,非常迷惑,在此将自己的理解记录下来,以便后续学习 1,NUMA架构和memory node 内存节点基于硬件 NUMA 创建,memory node是Numa node内的内存块,属于server物理内存的一部分.Memory Node的作用是使得内存的分配由Windows移交到SQL Server OS层面执行. 查看memory node select *

SQL Server 内存中OLTP内部机制概述(二)

----------------------------我是分割线------------------------------- 本文翻译自微软白皮书<SQL Server In-Memory OLTP Internals Overview>:http://technet.microsoft.com/en-us/library/dn720242.aspx 译者水平有限,如有翻译不当之处,欢迎指正. ----------------------------我是分割线---------------

SQL Server内存不足解决,以及涉及到的知识点

首选,感谢博主shield-hand的一篇文章(ms sql server缓存清除与内存释放).写的非常细致.简洁.我这里并不是自己写博客,而是用自己的思维将众多博文或官网资料做一次整合.  在讲解问题发生原因之前,我先贴出来解决方案.之后再详细剖析其深层次的原因. ms sql server缓存清除与内存释放这篇文章已经给出了非常完美的方案,我就不再赘述了.有一个问题需要注意下,就是脚本操作中最好修个成以下形式: USE [IVMS8100] GO /****** Object: Stored

SQL SERVER 内存分配及常见内存问题(2)——DMV查询

原文:SQL SERVER 内存分配及常见内存问题(2)--DMV查询 内存动态管理视图(DMV): 从sys.dm_os_memory_clerks开始. SELECT [type] , SUM(virtual_memory_reserved_kb) AS [VM Reserved] , SUM(virtual_memory_committed_kb) AS [VM Committed] , SUM(awe_allocated_kb) AS [AWE Allocated] , SUM(shar