Destino de emparelhamento de evento
O destino de emparelhamento de eventos efetua a correspondência entre dois eventos por meio de uma ou mais colunas de dados presentes em cada evento. Muitos eventos vêm em pares, por exemplo, aquisições de bloqueio e liberações de bloqueio. Após o emparelhamento de uma sequência de eventos, ambos são descartados. O descarte de conjuntos correspondidos facilita a detecção de aquisições de bloqueios que não foram liberados.
Com o uso de filtros no nível de evento, o destino de emparelhamento pode ser usado somente para capturar eventos que não correspondam aos critérios predefinidos.
Ao usar o destino de emparelhamento de evento, você pode escolher dois eventos que serão correspondidos, junto com uma sequência de colunas para executar a correspondência. Todas as colunas nessa sequência deverão ser do mesmo tipo.
A tabela a seguir descreve as opções disponíveis para configurar um emparelhamento de evento.
Opção |
Valores permitidos |
Descrição |
---|---|---|
begin_event |
Qualquer nome de evento presente na sessão atual. |
O nome do evento que especifica o evento inicial em uma sequência emparelhada. |
end_event |
Qualquer nome de evento presente na sessão atual. |
O nome do evento que especifica o evento final em uma sequência emparelhada. |
begin_matching_columns |
Uma lista delimitada por vírgula, ordenada por nomes de coluna. |
As colunas em que a correspondência deve ser executada. |
end_matching_columns |
Uma lista delimitada por vírgula, ordenada por nomes de coluna. |
As colunas em que a correspondência deve ser executada. |
begin_matching_actions |
Uma lista de ações ordenadas, delimitadas por vírgula. |
As ações nas quais a correspondência deve ser executada. |
end_matching_actions |
Uma lista de ações ordenadas, delimitadas por vírgula. |
As ações nas quais a correspondência deve ser executada. |
respond_to_memory_pressure |
Um dos seguintes valores:
|
A resposta de destino a eventos de memória. Se definido como 1 e o servidor estiver com pouca memória, as informações não emparelhadas que estão sendo mantidas serão removidas. |
max_orphans |
Especifica o número total de eventos ímpares que serão coletados no destino. Quando o limite é atingido, os eventos não emparelhados são removidos na base PEPS (primeiro a entrar, primeiro a sair). Padrão = 10,000. |
Todos os dados associados a um evento são capturados e armazenados para emparelhamento futuro. Além disso, dados adicionados por ações também são coletados. Os dados de evento coletados são armazenados na memória e, portanto, têm um limite finito. Esse limite é baseado na capacidade e na atividade do sistema. Em vez de usar a quantidade máxima de memória a ser usada como um parâmetro, a quantidade de memória usada terá como base os recursos disponíveis do sistema. Quando esses não estiverem disponíveis, os eventos não emparelhados que foram retidos serão cancelados. Se um evento não tiver sido emparelhado e for cancelado, o evento correspondente aparecerá como um evento não emparelhado.
O destino de emparelhamento serializa eventos não emparelhados em um formato XML. Esse formato não se adapta a nenhum esquema. O formato contém apenas dois tipos de elementos. O elemento <unpaired> é a raiz, seguida por um. O elemento <event> para cada evento não emparelhando que está sendo controlado no momento. O elemento <event> contém um atributo que tem o nome do evento não emparelhado.
Adicionando o destino a uma sessão
Para adicionar o destino de correspondência de par a uma sessão de Eventos Estendidos, você deve incluir a instrução a seguir ao criar ou alterar uma sessão de evento:
ADD TARGET package0.pair_matching
Isso deve ser seguido por uma instrução SET, para definir os eventos iniciais e finais e quais ações ou colunas devem ser correspondidas. O exemplo a seguir mostra a sintaxe de exemplo para correspondência de par de eventos sqlserver.lock_acquired e sqlserver.lock_released.
( SET begin_event = 'sqlserver.lock_acquired',
begin_matching_columns = 'database_id, resource_0, resource_1, resource_2, transaction_id, mode',
end_event = 'sqlserver.lock_released',
end_matching_columns = 'database_id, resource_0, resource_1, resource_2, transaction_id, mode',
respond_to_memory_pressure = 1)
Para obter mais informações, consulte Determinar quais consultas estão mantendo bloqueios.
Revisando a saída de destino
Para revisar a saída do destino da correspondência de pares, você pode usar a consulta a seguir substituindo session_name pelo nome da sessão de evento.
SELECT name, target_name, CAST(xet.target_data AS xml)
FROM sys.dm_xe_session_targets AS xet
JOIN sys.dm_xe_sessions AS xe
ON (xe.address = xet.event_session_address)
WHERE xe.name = 'session_name'
O exemplo a seguir mostra o formato de saída do destino do emparelhamento.
<unpaired truncated = "0" matchedCount = "[matched count]" memoryPressureDroppedCount = " [lost count]">
<event name = "[event name]" package = "[package]" id= "[event ID value]" version = "[event version]">
<data name = "[column name]">
<type name = "[column type]" package = "[type package]" />
<value>[column value]</value>
<text value>[text value]</text>>
</data>
</event>
</unpaired>
Consulte também
Referência
sys.dm_xe_session_targets (Transact-SQL)
CREATE EVENT SESSION (Transact-SQL)
ALTER EVENT SESSION (Transact-SQL)