Visualizzare l'utilizzo della capacità nella piattaforma di strumenti analitici
Questo articolo illustra come visualizzare l'utilizzo della capacità nell'appliance SQL Server Parallel Data Warehouse (PDW).
Per visualizzare l'utilizzo della capacità tramite la console di Amministrazione
Per visualizzare lo spazio usato, aprire la console Amministrazione e selezionare la scheda Archiviazione. È disponibile una scheda Archiviazione per l'area PDW.
Per visualizzare l'utilizzo della capacità tramite query
Per comprendere se un nodo è in esecuzione insufficiente nello spazio, il sistema di monitoraggio dell'integrità SQL Server PDW monitora già lo spazio disponibile per tutti i volumi all'interno di ogni nodo.
Se lo spazio disponibile all'interno di un volume scende al di sotto del 30%, SQL Server PDW genera un avviso in sys.dm_pdw_component_health_active_alerts. L'avviso rimane fino a quando non viene reso disponibile dello spazio libero.
Se lo spazio disponibile all'interno di un volume scende al di sotto del 10%, SQL Server PDW genera un avviso critico. Questa situazione è considerata critica perché le query potrebbero non riuscire se causano l'espansione del database.
Per recuperare l'utilizzo del volume, vedere l'esempio seguente.
SELECT
space.[pdw_node_id] ,
space.[node_name] ,
MAX(space.[volume_name]) AS 'volume_name' ,
MAX(space.[volume_size_mb]) AS 'volume_size_mb' ,
MAX(space.[free_space_mb]) AS 'free_space_mb' ,
(MAX(space.[volume_size_mb]) - MAX(space.[free_space_mb])) AS 'space_utilized'
FROM (
SELECT
s.[pdw_node_id],
n.[name] AS [node_name],
(CASE WHEN p.property_name = 'volume_name'
THEN s.[property_value] ELSE NULL END) AS 'volume_name' ,
(CASE WHEN p.property_name = 'volume_size'
THEN (CAST(ISNULL(s.[property_value], '0') AS BIGINT)/1024/1024)
ELSE 0 END) AS 'volume_size_mb' ,
(CASE WHEN p.property_name = 'volume_free_space'
THEN (CAST(ISNULL(s.[property_value], '0') AS BIGINT)/1024/1024)
ELSE 0 END) AS 'free_space_mb' , s.[component_instance_id]
FROM [sys].[dm_pdw_component_health_status] AS s
JOIN sys.dm_pdw_nodes AS n
ON s.[pdw_node_id] = n.[pdw_node_id]
JOIN [sys].[pdw_health_components] AS c
ON s.[component_id] = c.[component_id]
JOIN [sys].[pdw_health_component_properties] AS p
ON s.[property_id] = p.[property_id] AND s.[component_id] = p.[component_id]
WHERE
c.[Component_name] = 'Volume'
AND p.[property_name] IN ('volume_name', 'volume_free_space', 'volume_size')
) AS space
GROUP BY space.[pdw_node_id] , space.[node_name] , space.[component_instance_id]
ORDER BY space.[pdw_node_id], MAX(space.[volume_name]);
Per recuperare lo spazio usato dai database tra i nodi dell'appliance, vedere l'esempio seguente.
SELECT
[pdw_node_id],
[db_name],
SUM(CASE WHEN [file_type] = 'DATA' THEN [value_MB] ELSE 0 END) AS [DataSizeMB],
SUM(CASE WHEN [file_type] = 'LOG' THEN [value_MB] ELSE 0 END) AS [LogSizeMB],
SUM([value_MB]) AS [TotalMB]
FROM (
SELECT
pc.[pdw_node_id],
RTRIM(pc.[counter_name]) AS [counter_name],
ISNULL(d.[name], pc.[instance_name]) AS [db_name],
pc.[cntr_value]/1024 AS [value_MB],
CASE
WHEN [counter_name] LIKE 'Data File(s) Size%'
THEN 'DATA'
ELSE 'LOG'
END AS [file_type]
FROM sys.dm_pdw_nodes_os_performance_counters AS pc
LEFT JOIN sys.pdw_database_mappings AS dm
ON pc.instance_name = dm.physical_name
INNER JOIN sys.databases AS d
ON d.database_id = dm.database_id
WHERE
([counter_name] LIKE 'Log File(s) Size%'
OR [counter_name] LIKE 'Data File(s) Size%')
AND (d.[name] <> dm.[physical_name]
OR pc.[instance_name] = 'tempdb')
) AS db
GROUP BY [pdw_node_id], [db_name]
ORDER BY [db_name], [pdw_node_id];