sys.dm_os_memory_objects (Transact-SQL)

Gilt für:SQL ServerAzure SQL-DatenbankAzure SQL Managed InstanceAzure Synapse AnalyticsAnalytics Platform System (PDW)

Gibt Speicherobjekte zurück, die derzeit von SQL Server zugeordnet sind. Sie können sys.dm_os_memory_objects verwenden, um die Speichernutzung zu analysieren und mögliche Speicherverluste zu identifizieren.

Hinweis

Um dies von Azure Synapse Analytics oder Analytics Platform System (PDW) aufzurufen, verwenden Sie den Namen sys.dm_pdw_nodes_os_memory_objects. Diese Syntax wird vom serverlosen SQL-Pool in Azure Synapse Analytics nicht unterstützt.

Spaltenname Datentyp Beschreibung
memory_object_address varbinary(8) Adresse des Speicherobjekts. Lässt keine NULL-Werte zu.
parent_address varbinary(8) Adresse des übergeordneten Speicherobjekts. Lässt NULL-Werte zu.
pages_allocated_count int Gilt für: SQL Server 2008 (10.0.x) bis SQL Server 2008 R2 (10.50.x).

Anzahl der von diesem Objekt zugeordneten Seiten. Lässt keine NULL-Werte zu.
pages_in_bytes bigint Gilt für: SQL Server 2012 (11.x) und höher.

Arbeitsspeicher in Bytes, der von dieser Instanz des Arbeitsspeicherobjekts zugeordnet wird. Lässt keine NULL-Werte zu.
creation_options int Nur zur internen Verwendung. Lässt NULL-Werte zu.
bytes_used bigint Nur zur internen Verwendung. Lässt NULL-Werte zu.
type nvarchar(60) Typ des Speicherobjekts:

Dies gibt eine Komponente an, zu der dieses Speicherobjekt gehört, oder die Funktion des Speicherobjekts. Lässt NULL-Werte zu.
name varchar(128) Nur zur internen Verwendung. NULL-Werte sind zulässig.
memory_node_id smallint ID eines Speicherknotens, der von diesem Speicherobjekt verwendet wird. Lässt keine NULL-Werte zu.
creation_time datetime Nur zur internen Verwendung. Lässt NULL-Werte zu.
max_pages_allocated_count int Gilt für: SQL Server 2008 (10.0.x) bis SQL Server 2008 R2 (10.50.x).

Maximale Anzahl der von diesem Speicherobjekt zugeordneten Seiten. Lässt keine NULL-Werte zu.
page_size_in_bytes int Gilt für: SQL Server 2012 (11.x) und höher.

Größe der von diesem Objekt zugeordneten Seiten in Bytes. Lässt keine NULL-Werte zu.
max_pages_in_bytes bigint Höchstmenge an Arbeitsspeicher, die je von diesem Arbeitsspeicherobjekt verwendet wurde. Lässt keine NULL-Werte zu.
page_allocator_address varbinary(8) Speicheradresse der Seitenzuordnung. Lässt keine NULL-Werte zu. Weitere Informationen finden Sie unter sys.dm_os_memory_clerks (Transact-SQL).
creation_stack_address varbinary(8) Nur zur internen Verwendung. Lässt NULL-Werte zu.
sequence_num int Nur zur internen Verwendung. Lässt NULL-Werte zu.
partition_type int Gilt für: SQL Server 2016 (13.x) und höher.

Der Typ der Partition:

0 – Nicht partitionierbares Speicherobjekt

1 : Partitionierbares Speicherobjekt, derzeit nicht partitioniert

2 – Partitionierbares Speicherobjekt, partitioniert durch NUMA-Knoten. In einer Umgebung mit einem einzelnen NUMA-Knoten entspricht dies 1.

3 – Partitionierbares Speicherobjekt, partitioniert von CPU.
contention_factor real Gilt für: SQL Server 2016 (13.x) und höher.

Ein Wert, der den Inhalt dieses Speicherobjekts angibt, wobei 0 bedeutet, dass es keine Begnügung gibt. Der Wert wird aktualisiert, wenn während dieses Zeitraums eine bestimmte Anzahl von Speicherzuweisungen vorgenommen wurde. Gilt nur für threadsichere Speicherobjekte.
waiting_tasks_count bigint Gilt für: SQL Server 2016 (13.x) und höher.

Die Anzahl der Wartezeiten für dieses Speicherobjekt. Dieser Zähler wird immer dann erhöht, wenn dieser Speicher von diesem Speicherobjekt zugewiesen wird. Das Inkrement ist die Anzahl der Aufgaben, die derzeit auf den Zugriff auf dieses Speicherobjekt warten. Gilt nur für threadsichere Speicherobjekte. Dies ist ein Best-Effort-Wert ohne Korrektheitsgarantie.
exclusive_access_count bigint Gilt für: SQL Server 2016 (13.x) und höher.

Gibt an, wie oft auf dieses Speicherobjekt exklusiv zugegriffen wurde. Gilt nur für threadsichere Speicherobjekte. Dies ist ein Best-Effort-Wert ohne Korrektheitsgarantie.
pdw_node_id int Gilt für: Azure Synapse Analytics, Analytics Platform System (PDW)

Der Bezeichner für den Knoten, auf dem sich diese Verteilung befindet.

partition_type, contention_factor, waiting_tasks_count und exclusive_access_count sind noch nicht in SQL-Datenbank implementiert.

Berechtigungen

Für SQL Server und SQL Managed Instance ist die VIEW SERVER STATE-Berechtigung erforderlich.

Für SQL-Datenbank Standard-, S0- und S1-Dienstziele sowie für Datenbanken in elastischen Pools ist das Serveradministratorkonto, das Microsoft Entra-Administratorkonto oder die Mitgliedschaft in der ##MS_ServerStateReader##Serverrolle erforderlich. Für alle anderen SQL-Datenbank-Dienstziele ist entweder die VIEW DATABASE STATE-Berechtigung für die Datenbank oder die Mitgliedschaft in der ##MS_ServerStateReader##-Serverrolle erforderlich.

Berechtigungen für SQL Server 2022 und höher

Erfordert die VIEW SERVER PERFORMANCE STATE-Berechtigung auf dem Server.

Hinweise

Speicherobjekte sind Heaps. Sie stellen im Vergleich zu den Arbeitsspeicherclerks Zuordnungen mit feinerer Granularität bereit. SQL Server-Komponenten verwenden Speicherobjekte anstelle von Speicherbearbeitern. Speicherobjekte verwenden die Seitenzuordnungsschnittstelle des Arbeitsspeicherclerks für die Zuordnung von Seiten. Speicherobjekte verwenden keine Schnittstellen, die auf virtuellem Speicher oder Shared Memory basieren. Abhängig von den Zuordnungsmustern können Komponenten verschiedene Typen von Speicherobjekten erstellen, um Bereiche zufälliger Größe zuzuordnen.

Die Standardseitengröße eines Speicherobjekts beträgt 8 kB. Inkrementelle Speicherobjekte können jedoch Seitengrößen zwischen 512 Bytes und 8 kB aufweisen.

Hinweis

Die Seitengröße entspricht nicht der maximalen Zuordnung. Die Seitengröße ist vielmehr eine Zuordnungseinheit, die von einer Seitenzuordnung unterstützt und von einem Arbeitsspeicherclerk implementiert wird. Sie können von Arbeitsspeicherobjekten größere Zuordnungen als 8 KB anfordern.

Beispiele

Im folgenden Beispiel wird der von den einzelnen Speicherobjekttypen zugeordnete Speicherumfang zurückgegeben.

SELECT SUM (pages_in_bytes) as 'Bytes Used', type   
FROM sys.dm_os_memory_objects  
GROUP BY type   
ORDER BY 'Bytes Used' DESC;  
GO  

Siehe auch

Dynamische Verwaltungssichten in Verbindung mit dem SQL Server-Betriebssystem (Transact-SQL)
sys.dm_os_memory_clerks (Transact-SQL)