Freigeben über


sys.dm_os_memory_objects (Transact-SQL)

Gibt Speicherobjekte zurück, die derzeit von SQL Server zugeordnet werden. sys.dm_os_memory_objects wird für die Analyse der Speichernutzung und zur Identifizierung möglicher Speicherverluste verwendet.

Gilt für: SQL Server (SQL Server 2008 bis aktuelle Version).

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

Anzahl der von diesem Objekt zugeordneten Seiten. Lässt keine NULL-Werte zu.

Gilt für: SQL Server 2008 bis SQL Server 2008 R2.

pages_in_bytes

bigint

Arbeitsspeicher in Bytes, der von dieser Instanz des Arbeitsspeicherobjekts zugeordnet wird. Lässt keine NULL-Werte zu.

Gilt für: SQL Server 2012 bis SQL Server 2014.

creation_options

int

Nur interne Verwendung. Lässt NULL-Werte zu.

bytes_used

bigint

Nur zur internen Verwendung. Lässt NULL-Werte zu.

Typ

nvarchar(60)

Typ des Speicherobjekts:

Hiermit wird eine Komponente angegeben, 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 interne Verwendung. Lässt NULL-Werte zu.

max_pages_allocated_count

int

Maximale Anzahl der von diesem Speicherobjekt zugeordneten Seiten. Lässt keine NULL-Werte zu.

Gilt für: SQL Server 2008 bis SQL Server 2008 R2.

page_size_in_bytes

int

Größe der von diesem Objekt zugeordneten Seiten in Bytes. Lässt keine NULL-Werte zu.

Gilt für: SQL Server 2012 bis SQL Server 2014.

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.

Berechtigungen

Erfordert die VIEW SERVER 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 Arbeitsspeicherobjekte anstelle der Arbeitsspeicherclerks. 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

Verweis

Dynamische Verwaltungssichten und Funktionen (Transact-SQL)

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

sys.dm_os_memory_clerks (Transact-SQL)