sys.dm_os_tasks (Transact-SQL)
Aplica-se a: SQL Server Banco de Dados SQL do Azure Instância Gerenciada de SQL do Azure PDW (Sistema de Plataforma de Análise) do Azure Synapse Analytics
Retorna uma linha para cada tarefa ativa na instância do SQL Server. Uma tarefa é a unidade básica de execução no SQL Server. Exemplos de tarefas incluem uma consulta, um logon, um logout e tarefas do sistema, como atividade de limpeza fantasma, atividade de ponto de verificação, gravador de log, atividade de refazer paralela. Para obter mais informações sobre tarefas, consulte o Guia de Arquitetura de Thread e Tarefa.
Observação
Para chamar isso do Azure Synapse Analytics ou do PDW (Analytics Platform System), use o nome sys.dm_pdw_nodes_os_tasks. Não há suporte a essa sintaxe para o pool de SQL sem servidor no Azure Synapse Analytics.
Nome da coluna | Tipo de dados | Descrição |
---|---|---|
task_address | varbinary(8) | Endereço de memória do objeto. |
task_state | nvarchar(60) | O estado da tarefa. Pode ser um dos seguintes: PENDING: Esperando por um thread de trabalho. RUNNABLE: Executável, mas esperando receber um quantum. RUNNING: Atualmente em execução no agendador. SUSPENDED: Tem um trabalhador, mas está esperando por um evento. DONE: Concluído. SPINLOOP: Preso em um spinlock. |
context_switches_count | int | Número de alternâncias de contexto de agendador que esta tarefa completou. |
pending_io_count | int | Número de E/Ss físicas executadas por esta tarefa. |
pending_io_byte_count | bigint | Contagem total de bytes de E/Ss que são executadas por esta tarefa. |
pending_io_byte_average | int | Contagem média de bytes de E/Ss que são executadas por esta tarefa. |
scheduler_id | int | ID do agendador pai. Este é um identificador das informações de agendador para esta tarefa. Para obter mais informações, confira sys.dm_os_schedulers (Transact-SQL). |
session_id | smallint | ID da sessão que está associado à tarefa. |
exec_context_id | int | ID do contexto de execução que está associado à tarefa. |
request_id | int | ID da solicitação da tarefa. Para obter mais informações, confira sys.dm_exec_requests (Transact-SQL). |
worker_address | varbinary(8) | Endereço de memória do trabalhador que está executando a tarefa. NULL = A tarefa está esperando que um trabalhador possa ser executado ou a execução da tarefa foi recém-concluída. Para obter mais informações, consulte sys.dm_os_workers (Transact-SQL). |
host_address | varbinary(8) | Endereço de memória do host. 0 = A hospedagem não foi usada para criar a tarefa. Isto ajuda a identificar o host que foi usado para criar esta tarefa. Para obter mais informações, consulte sys.dm_os_hosts (Transact-SQL). |
parent_task_address | varbinary(8) | Endereço de memória da tarefa que é pai do objeto. |
pdw_node_id | int | Aplica-se a: Azure Synapse Analytics, Analytics Platform System (PDW) O identificador do nó em que essa distribuição está ativada. |
Permissões
No SQL Server e na Instância Gerenciada de SQL, requer a permissão VIEW SERVER STATE
.
Nos objetivos de serviço Básico, S0 e S1 do Banco de Dados SQL e para bancos de dados em pools elásticos, a conta de administrador do servidor, a conta de administrador do Microsoft Entra ou a ##MS_ServerStateReader##
associação na função de servidor são necessárias. Em todos os outros objetivos de serviço do Banco de Dados SQL, a permissão VIEW DATABASE STATE
no banco de dados ou a associação à função de servidor ##MS_ServerStateReader##
são necessárias.
Permissões do SQL Server 2022 e posteriores
É necessária a permissão VIEW SERVER PERFORMANCE STATE no servidor.
Exemplos
R. Monitorando solicitações paralelas
Para solicitações executadas em paralelo, você verá várias linhas para a mesma combinação de (<session_id>,< request_id).> Use a consulta a seguir para localizar a opção Configurar o grau máximo de paralelismo do servidor para todas as solicitações ativas.
Observação
Um request_id é exclusivo em uma sessão.
SELECT
task_address,
task_state,
context_switches_count,
pending_io_count,
pending_io_byte_count,
pending_io_byte_average,
scheduler_id,
session_id,
exec_context_id,
request_id,
worker_address,
host_address
FROM sys.dm_os_tasks
ORDER BY session_id, request_id;
B. Associando IDs de sessão a threads do Windows
Você pode usar a consulta a seguir para associar um valor de ID de sessão a um ID de thread do Windows. Depois, poderá monitorar o desempenho do thread no Monitor de Desempenho do Windows. A consulta a seguir não retorna informações de sessões que estão suspensas.
SELECT STasks.session_id, SThreads.os_thread_id
FROM sys.dm_os_tasks AS STasks
INNER JOIN sys.dm_os_threads AS SThreads
ON STasks.worker_address = SThreads.worker_address
WHERE STasks.session_id IS NOT NULL
ORDER BY STasks.session_id;
GO
Confira também
Exibições de gerenciamento dinâmico relacionadas ao sistema operacional do SQL Server (Transact-SQL)
Guia de arquitetura de thread e tarefa