sys.dm_xtp_system_memory_consumers (Transact-SQL)

适用于: SQL Server Azure SQL 数据库 Azure SQL 托管实例

报告内存中 OLTP 的系统级内存使用者。 用于这些消耗者的内存来自默认池(在用户线程的背景下分配时)或来自内部池(如果在系统线程的背景下分配)。

SELECT *
FROM sys.dm_xtp_system_memory_consumers;

有关详细信息,请参阅 内存中 OLTP(内存中优化)

列名称 类型 描述
memory_consumer_id bigint 内存消耗者的内部 ID。
memory_consumer_type int 表示内存消耗者类型的整数,具有以下值之一:

0 - 不应显示。 聚合两个或多个使用者的内存使用量。

1 - LOOKASIDE:跟踪系统后备链的内存占用情况。

2 - VARHEAP:跟踪长度可变的堆的内存占用情况。

4 - IO 页池:跟踪用于 IO 操作的系统页池的内存占用情况。
memory_consumer_type_desc nvarchar(16) 对内存消耗者类型的说明:

0 - 不应显示

1 - LOOKASIDE

2 - VARHEAP

4 - PGPOOL
memory_consumer_desc nvarchar(64) 对内存消耗者实例的说明:

VARHEAP:
系统堆。 通用。 当前仅用于分配垃圾收集工作项。
- 或 -
后备链堆。 后备链在后备链表中包含的项目数达到预先确定的上限(通常约 5,000 项)时使用。

PGPOOL:对于 IO 系统池,有三种不同的大小:系统 4K 页池、系统 64-K 页池和 System 256-K 页面池。
lookaside_id bigint 线程本地后备链内存提供程序的 ID。
pagepool_id bigint 线程本地页池内存提供程序的 ID。
allocated_bytes bigint 为此消耗者保留的字节数。
used_bytes bigint 此消耗者使用的字节数。 仅适用于 varheap 内存消耗者。

从 SQL Server 2022(16.x)开始,适用于 varheap 和 lookaside 内存使用者。
allocation_count int 分配的数量。

从 SQL Server 2022 (16.x)开始,系统堆中用于查找内存使用者的分配数。
partition_count int 仅供内部使用。
sizeclass_count int 仅供内部使用。
min_sizeclass int 仅供内部使用。
max_sizeclass int 仅供内部使用。
memory_consumer_address varbinary 消耗者的内部地址。

权限

要求对服务器拥有 VIEW SERVER STATE 权限。

SQL Server 2022 及更高版本的权限

要求对服务器具有 VIEW SERVER PERFORMANCE STATE 权限。

注解

在 SQL Server 2022(16.x)中,此 DMV 具有特定于内存优化 TempDB 元数据内存改进的其他列。

示例

此示例输出 SQL Server 实例的系统内存消耗者:

SELECT memory_consumer_type_desc,
       memory_consumer_desc,
       allocated_bytes / 1024 as allocated_bytes_kb,
       used_bytes / 1024 as used_bytes_kb,
       allocation_count
FROM sys.dm_xtp_system_memory_consumers;

该输出显示系统级别的所有内存消耗者。 例如,存在事务后备链的消耗者。

memory_consumer_type_desc                memory_consumer_desc                           allocated_bytes_kb   used_bytes_kb        allocation_count
-------------------------------          ---------------------                          -------------------  --------------       ----------------
VARHEAP                                  Lookaside heap                                 0                    0                    0
VARHEAP                                  System heap                                    768                  0                    2
LOOKASIDE                                GC transaction map entry                       64                   64                   910
LOOKASIDE                                Redo transaction map entry                     128                  128                  1260
LOOKASIDE                                Recovery table cache entry                     448                  448                  8192
LOOKASIDE                                Transaction recent rows                        3264                 3264                 4444
LOOKASIDE                                Range cursor                                   0                    0                    0
LOOKASIDE                                Hash cursor                                    3200                 3200                 11070
LOOKASIDE                                Transaction save-point set entry               0                    0                    0
LOOKASIDE                                Transaction partially-inserted rows set        704                  704                  1287
LOOKASIDE                                Transaction constraint set                     576                  576                  1940
LOOKASIDE                                Transaction save-point set                     0                    0                    0
LOOKASIDE                                Transaction write set                          704                  704                  672
LOOKASIDE                                Transaction scan set                           320                  320                  156
LOOKASIDE                                Transaction read set                           704                  704                  343
LOOKASIDE                                Transaction                                    4288                 4288                 1459
PGPOOL                                   System 256K page pool                          5120                 5120                 20
PGPOOL                                   System 64K page pool                           0                    0                    0
PGPOOL                                   System 4K page pool                            24                   24                   6

查看由系统分配器占用的总内存:

SELECT SUM(allocated_bytes) / (1024 * 1024) AS total_allocated_MB,
       SUM(used_bytes) / (1024 * 1024) AS total_used_MB
FROM sys.dm_xtp_system_memory_consumers;

下面是结果集:

total_allocated_MB   total_used_MB
-------------------- --------------------
2                    2