SQLServer的内存管理架构

这篇具有很好参考价值的文章主要介绍了SQLServer的内存管理架构。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、Windows的虚拟内存管理器

地址空间的已提交区域由 Windows 虚拟内存管理器 (VMM) 映射到可用的物理内存。

虚拟内存系统允许物理内存的过度使用,因此虚拟内存与物理内存的比率可以超过 1:1。因此,较大的程序可以在具有各种物理内存配置的计算机上运行。但是,使用比所有进程的总平均工作集多得多的虚拟内存可能会导致性能不佳。

二、SQL Server 内存体系结构

SQL Server 根据需要动态获取和释放内存。通常,管理员不必指定应分配给 SQL Server 的内存量,尽管该选项仍然存在并且在某些环境中是必需的。

所有数据库软件的主要设计目标之一是最小化磁盘 I/O,因为磁盘读取和写入是最耗费资源的操作之一。SQL Server 在内存中构建一个缓冲池,以保存从数据库中读取的页。SQL Server 中的许多代码专用于最大程度地减少磁盘和缓冲池之间的物理读取和写入次数。SQL Server 试图在两个目标之间取得平衡:

  • 防止缓冲池变得太大,以致整个系统内存不足。
  • 通过最大化缓冲池的大小,最大限度地减少数据库文件的物理 I/O。

在负载较重的系统中,某些需要大量内存才能运行的大型查询无法获取请求的最小内存量,并在等待内存资源时收到超时错误。若要解决此问题,请增加查询等待选项。对于并行查询,请考虑降低最大并行度选项。

在内存压力很大的系统中,当查询未获得位图所需的最小内存时,查询计划中具有合并联接、排序和位图的查询可能会删除位图。这可能会影响查询性能,如果排序过程无法容纳在内存中,则可能会增加数据库中工作表的使用量,从而导致增长。若要解决此问题,请添加物理内存,或调整查询以使用不同的更快查询计划。

2.1、传统(虚拟)内存

所有 SQL Server 版本都支持 64 位平台上的传统内存。SQL Server 进程可以访问虚拟地址空间,最高可达 x64 体系结构上的操作系统最大值(SQL Server 标准版最多支持 128 GB)。对于 IA64 体系结构,限制为 7 TB(SQL Server 64 (2012.x) 及更高版本不支持 IA11)。

2.2、地址窗口扩展 (AWE) 内存

通过使用地址窗口化扩展插件 (AWE) 和 AWE 所需的内存中锁定页 (LPIM) 特权,可以在低虚拟内存条件下将大部分 SQL Server 进程内存锁定在物理 RAM 中。这在 32 位和 64 位 AWE 分配中都会发生。发生内存锁定的原因是 AWE 内存不通过 Windows 中的虚拟内存管理器,该管理器控制内存分页。AWE 内存分配 API 需要“锁定内存中的页”(SeLockMemoryPrivilege) 权限。因此,使用 AWE API 的主要好处是在系统上存在内存压力时将大部分内存驻留在 RAM 中。

如果授予 LPIM,我们强烈建议您将最大服务器内存 (MB) 设置为特定值,而不是保留默认值 2,147,483,647 兆字节 (MB)。

如果未启用 LPIM,SQL Server 将切换到使用常规内存,并且在操作系统内存耗尽的情况下,错误日志中可能会报告错误 17890。

三、从 SQL Server 2012 (11.x) 开始发生的改变

3.1、对内存管理的更改

从 SQL Server 2012 (11.x) 开始,单页分配、多页分配和 CLR 分配都合并到“任何大小”页面分配器中,并包含在由最大服务器内存 (MB) 和最小服务器内存 (MB) 配置选项控制的内存限制中。此更改为通过 SQL Server 内存管理器的所有内存要求提供了更准确的大小调整功能。

从 SQL Server 2012 (11.x) 开始,SQL Server 分配的内存可能会超过最大服务器内存 (MB) 设置中指定的值。当总服务器内存 (KB) 值已达到目标服务器内存 (KB) 设置时,可能会发生此行为,如最大服务器内存 (MB) 指定。如果由于内存碎片而没有足够的连续可用内存来满足多页内存请求(超过 8 KB)的需求,则 SQL Server 可以执行过度使用,而不是拒绝内存请求。

执行此分配后,资源监视器后台任务将开始向所有内存使用者发出释放分配的内存的信号,并尝试使总服务器内存 (KB) 值低于目标服务器内存 (KB) 规范。因此,SQL Server 内存使用情况可能会短暂超过最大服务器内存 (MB) 设置。在此情况下,总服务器内存 (KB) 性能计数器读数将超过最大服务器内存 (MB) 和目标服务器内存 (KB) 设置。

3.2、对memory_to_reserve所做的更改

在较旧版本的 SQL Server 中,SQL Server 内存管理器留出一部分进程虚拟地址空间 (VAS) 供多页分配器 (MPA)、CLR 分配器、SQL Server 进程中线程堆栈的内存分配和直接窗口分配 (DWA) 使用。虚拟地址空间的这一部分也称为“内存要离开”或“非缓冲池”区域。

为这些分配保留的虚拟地址空间由memory_to_reserve配置选项确定。SQL Server 使用的默认值为 256 MB。

由于“任何大小”页面分配器还处理大于 8 KB 的分配,因此memory_to_reserve值不包括多页分配。除此更改外,此配置选项的其他所有内容都保持不变。

四、动态内存管理

SQL Server 数据库引擎的默认内存管理行为是根据需要获取尽可能多的内存,而不会在系统上造成内存不足。SQL Server 数据库引擎通过使用 Microsoft Windows 中的内存通知 API 来执行此操作。

当 SQL Server 动态使用内存时,它会定期查询系统以确定可用内存量。维护此可用内存可防止操作系统 (OS) 分页。如果可用内存较少,SQL Server 将向操作系统释放内存。如果有更多内存可用,SQL Server 可能会分配更多内存。SQL Server 仅在其工作负荷需要更多内存时才添加内存;静态服务器不会增加其虚拟地址空间的大小。如果您注意到任务管理器和性能监视器在使用动态内存管理时显示可用内存稳定减少,这是默认行为,不应被视为内存泄漏。

最大服务器内存控制 SQL Server 内存分配、编译内存、所有缓存(包括缓冲池)、查询执行内存授予、锁管理器内存和 CLR1记忆(基本上是在sys.dm_os_memory_clerks中找到的任何记忆职员)。

CLR 内存在从 SQL Server 2012 (11.x) 开始的max_server_memory分配下进行管理。

示例:查询返回有关当前分配的内存的信息。

SELECT
  physical_memory_in_use_kb/1024 AS sql_physical_memory_in_use_MB,
    large_page_allocations_kb/1024 AS sql_large_page_allocations_MB,
    locked_page_allocations_kb/1024 AS sql_locked_page_allocations_MB,
    virtual_address_space_reserved_kb/1024 AS sql_VAS_reserved_MB,
    virtual_address_space_committed_kb/1024 AS sql_VAS_committed_MB,
    virtual_address_space_available_kb/1024 AS sql_VAS_available_MB,
    page_fault_count AS sql_page_fault_count,
    memory_utilization_percentage AS sql_memory_utilization_percentage,
    process_physical_memory_low AS sql_process_physical_memory_low,
    process_virtual_memory_low AS sql_process_virtual_memory_low
FROM sys.dm_os_process_memory;

4.1、堆栈大小

线程堆栈的内存、CLR、文件.dll扩展过程、分布式查询引用的 OLE DB 提供程序、Transact-SQL 语句中引用的自动化对象以及非 SQL Server DLL 分配的任何内存不受最大服务器内存 (MB) 的控制。

当 SQL Server 启动时,它会根据多个参数(如系统上的物理内存量、服务器线程数和各种启动参数)计算缓冲池的虚拟地址空间的大小。SQL Server 为缓冲池保留其进程虚拟地址空间的计算量,但它仅获取(提交)当前加载所需的物理内存量。

然后,实例会根据需要继续获取内存以支持工作负载。随着越来越多的用户连接和运行查询,SQL Server 会按需获取更多的物理内存。SQL Server 实例继续获取物理内存,直到达到其最大服务器内存 (MB) 分配目标或操作系统指示不再有多余的可用内存;当内存超过最小服务器内存设置时,它会释放内存,并且操作系统指示可用内存不足。

当其他应用程序在运行 SQL Server 实例的计算机上启动时,它们会消耗内存,并且可用物理内存量将低于 SQL Server 目标。SQL Server 实例调整其内存消耗。如果另一个应用程序停止并且有更多内存可用,则 SQL Server 实例会增加其内存分配的大小。SQL Server 每秒可以释放和获取几兆字节的内存,从而能够快速适应内存分配更改。

五、缓冲区管理

SQL Server 数据库的主要用途是存储和检索数据,因此密集磁盘 I/O 是数据库引擎的核心特征。由于磁盘 I/O 操作可能会消耗许多资源并且需要相对较长的时间才能完成,因此 SQL Server 专注于提高 I/O 的效率。缓冲液管理是实现这种效率的关键组成部分。缓冲区管理组件由两种机制组成:用于访问和更新数据库页的缓冲区管理器,以及用于减少数据库文件 I/O 的缓冲区缓存(也称为缓冲池)。

5.1、缓冲区管理的工作原理

缓冲区是内存中的 8 KB 页,大小与数据页或索引页相同。因此,缓冲区缓存分为 8 KB 页。缓冲区管理器管理将数据或索引页从数据库磁盘文件读取到缓冲区缓存以及将修改的页写回磁盘的功能。页将保留在缓冲区缓存中,直到缓冲区管理器需要缓冲区来读取更多数据。仅当数据被修改时,数据才会写回磁盘。缓冲区缓存中的数据在写回磁盘之前可以多次修改。

当 SQL Server 启动时,它会根据多个参数(如系统上的物理内存量、配置的最大服务器线程数和各种启动参数)计算缓冲区缓存的虚拟地址空间的大小。SQL Server 为缓冲区缓存保留此计算量的进程虚拟地址空间(称为内存目标),但它仅获取(提交)当前加载所需的物理内存量。您可以查询sys.dm_os_sys_info目录视图中的committed_target_kb列和committed_kb列,以分别返回保留为内存目标的页数和缓冲区缓存中当前提交的页数。

SQL Server 启动和缓冲区缓存获取其内存目标之间的时间间隔称为上升。在此期间,读取请求会根据需要填充缓冲区。例如,单个 8 KB 页读取请求填充单个缓冲区页。这意味着上升取决于客户端请求的数量和类型。通过将单页读取请求转换为对齐的八页请求(构成一个范围)来加快提升速度。这使得爬坡可以更快地完成,尤其是在具有大量内存的机器上。

由于缓冲区管理器使用 SQL Server 进程中的大部分内存,因此它与内存管理器配合使用,以允许其他组件使用其缓冲区。缓冲区管理器主要与以下组件交互:

  • 资源管理器,用于控制总体内存使用情况,在 32 位平台中,用于控制地址空间使用情况。
  • 用于低级别文件 I/O 操作的数据库管理器和 SQL Server 操作系统 (SQLOS)。
  • 用于预写日志记录的日志管理器。

5.2、支持的功能

  • 缓冲区管理器可识别非一致性内存访问 (NUMA)。缓冲区缓存页分布在硬件 NUMA 节点上,这允许线程访问在本地 NUMA 节点上分配的缓冲区页,而不是从外部内存访问。

  • 缓冲区管理器支持热添加内存,允许用户在不重新启动服务器的情况下添加物理内存。

  • 缓冲区管理器支持 64 位平台上的大页面。页面大小特定于 Windows 版本。

  • 缓冲区管理器提供通过动态管理视图公开的额外诊断。可以使用这些视图监视特定于 SQL Server 的各种操作系统资源。

5.3、磁盘 I/O

缓冲区管理器仅执行对数据库的读取和写入。其他文件和数据库操作(如打开、关闭、扩展和收缩)由数据库管理器和文件管理器组件执行。

缓冲区管理器的磁盘 I/O 操作具有以下特征:

  • 所有 I/O 都是异步执行的,这允许调用线程继续处理,而 I/O 操作在后台进行。
  • 所有 I/O 都在调用线程中发出,除非正在使用关联 I/O 选项。关联性 I/O 掩码选项将 SQL Server 磁盘 I/O 绑定到指定的 CPU 子集。在高端 SQL Server 联机事务处理 (OLTP) 环境中,此扩展可以增强发出 I/O 的 SQL Server 线程的性能。
  • 多页 I/O 通过分散-收集 I/O 完成,这允许将数据传入或传出不连续的内存区域。这意味着 SQL Server 可以快速填充或刷新缓冲区缓存,同时避免多个物理 I/O 请求。

5.4、长 I/O 请求

缓冲区管理器报告任何未完成至少 15 秒的 I/O 请求。这有助于系统管理员区分 SQL Server 问题和 I/O 子系统问题。报告错误消息 833,并显示在 SQL Server 错误日志中。长 I/O 可以是读取或写入;消息中当前未指示。长 I/O 消息是警告,而不是错误。它们并不表示 SQL Server 的问题,而是表示底层 I/O 系统的问题。报告这些消息是为了帮助系统管理员更快地找到 SQL Server 响应时间不佳的原因,并区分 SQL Server 无法控制的问题。因此,它们不需要任何操作,但系统管理员应调查 I/O 请求花费这么长时间的原因,以及时间是否合理。

5.5、长时间 I/O 请求的原因

较长的 I/O 消息可能表示 I/O 被永久阻止且永远不会完成(称为丢失 I/O),或者只是表示它尚未完成。无法从消息中判断出哪种情况,尽管丢失的 I/O 通常会导致闩锁超时。
长 I/O 通常表示 SQL Server 工作负荷对于磁盘子系统来说过于密集。在以下情况下,可能指示磁盘子系统不足:

  • 在繁重的 SQL Server 工作负荷期间,错误日志中会出现多个长 I/O 消息。
  • 性能监视器计数器显示较长的磁盘延迟、较长的磁盘队列或无磁盘空闲时间。

长 I/O 也可能是由 I/O 路径中的组件(例如,驱动程序、控制器或固件)不断推迟处理旧的 I/O 请求,转而处理更接近磁盘磁头当前位置的新请求引起的。根据哪些请求最接近读/写头的当前位置来优先处理请求的常用技术称为“电梯搜索”。这可能很难用性能监视器工具证实,因为大多数 I/O 都会及时得到维护。执行大量顺序 I/O 的工作负载(如备份和还原、表扫描、排序、创建索引、批量加载和清零文件)可能会加剧长 I/O 请求。

六、了解非一致性内存访问

SQL Server 可识别非一致性内存访问 (NUMA),并且在没有特殊配置的 NUMA 硬件上表现良好。随着时钟速度和处理器数量的增加,减少使用这种额外处理能力所需的内存延迟变得越来越困难。为了规避这种情况,硬件供应商提供了大型 L3 缓存,但这只是一个有限的解决方案。NUMA 体系结构为此问题提供了可扩展的解决方案。

SQL Server 旨在利用基于 NUMA 的计算机,而无需进行任何应用程序更改。

SQLServer的内存管理架构文章来源地址https://www.toymoban.com/news/detail-415347.html

到了这里,关于SQLServer的内存管理架构的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • openstack虚拟机管理器显示内存与实际使用内存不符

    现象:研发反馈服务访问不了,登录检查发现openstack-3物理机里的多台虚拟机关机了 查看message,无明显报错,查看控制台内存(已用)104.5GB,还是有可剩余内存的, 经过长时间排查,发现这个参数仅仅只是当初建立虚拟机实例时,分配定额,例如你实例是8G,这里“内存(

    2024年02月13日
    浏览(42)
  • 深入理解Linux虚拟内存管理(六)

    Linux 内核设计与实现 深入理解 Linux 内核 Linux 设备驱动程序 Linux设备驱动开发详解 深入理解Linux虚拟内存管理(一) 深入理解Linux虚拟内存管理(二) 深入理解Linux虚拟内存管理(三) 深入理解Linux虚拟内存管理(四) 深入理解Linux虚拟内存管理(五) 深入理解Linux虚拟内存

    2024年02月08日
    浏览(48)
  • 虚拟内存之请求分页管理

    一、与基本分页存储管理的区别 程序执行过程中,访问信息不在内存时,OS需要从外存调入内存。——调页功能 内存空间不够时,OS需要将内存中暂时用不到的信息换出到外存。——页面置换功能 二、页表机制 1.页表:需要知道页面是否已经调入内存及页面的状态(是否有被

    2024年02月08日
    浏览(30)
  • Jtti:windows虚拟内存最小值太低如何解决

    当Windows虚拟内存的最小值设置过低时,可能会导致系统性能下降、应用程序崩溃甚至系统不稳定。解决方法包括: 调整虚拟内存设置: 可以通过以下步骤调整虚拟内存的设置: 右键点击“此电脑”或“计算机”,选择“属性”。 在左侧导航栏中,点击“高级系统设置”。

    2024年02月13日
    浏览(34)
  • JVM内存管理、内存分区:堆、方法区、虚拟机栈、本地方法栈、程序计数器

    线程共享 堆         存放 实例 ,字符串常量(直接引用),静态变量,线程分配缓冲区(TLAB线程私有)。 垃圾收集器 管理的区域 方法区         非堆,和堆相对的概念。存储已被虚拟机加载的 类型信息 、常量、静态变量、即时编译器编译后的代码缓存等数据,内

    2024年02月10日
    浏览(41)
  • flink内存管理(二):MemorySegment的设计与实现:(1)架构、(2)管理堆内/外内存、(3)写入/读取内存、(4)垃圾清理器

    在flink内存管理(一)中我们已经知道:在Flink中会将对象序列化成二进制格式数据,然后写入预先分配的内存块,而这个内存块就是MemorySegment。 MemorySegments作为Flink内存管理的最小内存分配单元, 能够申请堆内存和堆外内存空间 ,并对上层提供丰富且高效的内存数据读写方

    2024年01月22日
    浏览(43)
  • windows平台部署arm架构的虚拟机(实测截图)

    平台 windows 由于我近期有一个比赛,而我的主机又是x86架构的,人家要求使用arm架构的主机,我这穷屌丝,不可 能去买一台吧,而且随着国产系统的推进,采用arm架构的主机也越来越多,作为运维我们该怎么利用x86 来运行arm架构的主机成为了一个问题 以下软件版本皆为实验

    2023年04月21日
    浏览(32)
  • 深入探讨Java虚拟机(JVM):执行流程、内存管理和垃圾回收机制

    目录 什么是JVM? JVM 执行流程 JVM 运行时数据区 堆(线程共享) Java虚拟机栈(线程私有) 什么是线程私有? 程序计数器(线程私有) 方法区(线程共享) JDK 1.8 元空间的变化 运行时常量池 内存布局中的异常问题 1.  Java堆溢出 2.  虚拟机栈和本地方法栈溢出 JVM 类加载 1.

    2024年02月09日
    浏览(48)
  • 汽车ECU的虚拟化技术初探(四)--U2A内存管理

    目录 1.内存管理概述 2. 内存保护功能 2.1 SPID 2.2 Slave Guard 3.小结 为了讲清楚U2A 在各种运行模式、特权模式下的区别,其实首先应该搞清楚不同模式下可以操作的寄存器有哪些。 但是看到这个寄存器模型就头大。 再加上之前没有研究过G4MH的内核,所以这里暂且留个坑。 我们

    2024年01月20日
    浏览(34)
  • Docker容器与虚拟化技术:Docker架构、镜像管理

    目录 一、理论 1.Doker概述 2.Docker核心概念 3.Docker安装 4.Docker的镜像管理命令 二、实验 1.Docker安装 2.查看Docker信息 3.Docker的镜像管理命令 三、问题 1.如何注册Docker账号  2.如何设置Docker公共存储库 四、总结 (1) IT架构 裸金属 → 虚拟机 → 容器→ 函数化、代码化 云计算涌现出很

    2024年02月13日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包