Compartilhar via


Sessões de eventos estendidos do SQL Server

Uma sessão de eventos estendidos do SQL Server é criada no processo do SQL Server que está hospedando o mecanismo de eventos estendidos. Os seguintes aspectos de uma sessão de eventos estendidos fornecem um contexto para entender a infra-estrutura de eventos estendidos e o processamento geral que ocorre:

  • Estados de sessão. Os diferentes estados em que uma sessão de eventos estendidos se encontra quando as instruções CREATE EVENT SESSION e ALTER EVENT SESSION são executadas.

  • Conteúdo de sessão e características. O conteúdo de uma sessão do Extended Events, como destinos e eventos, e o modo como esses objetos estão relacionados em uma sessão ou entre sessões.

Estados da sessão

A ilustração a seguir mostra os vários estados de uma sessão de eventos estendidos.

Estado de sessão de eventos estendidos

Mencionando a figura precedente, observe que o estado da sessão é alterado quando os comandos DDL diferentes são emitidos para uma sessão de evento. Essas alterações de estado são descritas na tabela a seguir.

Rótulo de ilustração

instrução DDL

Descrição

Criar

CREATE EVENT SESSION

O processo do host cria um objeto de sessão que contém os metadados fornecidos pela CREATE EVENT SESSION. O processo do host valida a definição de sessão, valida o nível de permissão do usuário, e armazena os metadados no banco de dados mestre. Neste momento a sessão não está ativa.

Alterar

ALTER EVENT SESSION, STATE=START

O processo do host inicia a sessão. O processo do host lê os metadados armazenados, valida a definição da sessão, verifica o nível de permissão do usuário e cria a sessão. Objetos de sessão, como eventos e destinos, são carregados e a manipulação de eventos está ativa.

Alterar

ALTER EVENT SESSION, STATE=STOP

O processo do host pára a sessão ativa, mas retém os metadados.

Descartar

DROP EVENT SESSION

Dependendo se a sessão está ativa ou não, Descartar (DROP SESSION) excluirá os metadados e fechará a sessão ativa, ou excluirá os metadados da sessão.

ObservaçãoObservação

ALTER EVENT SESSION e DROP EVENT SESSION podem ser aplicados aos metadados, ou a uma sessão ativa e aos metadados.

Conteúdo da sessão e características

Sessões de evento estendidos têm limites implícitos sendo que a configuração de uma sessão não altera a configuração de outra sessão. Contudo, esses limites não impedem que um evento ou destino seja usado em mais de uma sessão.

A ilustração a seguir mostra o conteúdo da sessão e a relação entre pacotes e sessões.

Co-existência e compartilhamento de objetos em sessões.

Em relação à ilustração anterior, observe que:

  • O mapeamento entre objetos de pacote e sessões são muitos para muitos, o que significa que um objeto pode aparecer em várias sessões, e uma sessão pode conter vários objetos.

  • O mesmo evento (Evento 1) ou destino (Destino 1) pode ser habilitado em mais de uma sessão.

As sessões têm as seguintes características:

  • Ações e predicados estão associados a eventos em uma base por sessão. Se você tem o Evento 1 na Sessão A com a Ação 1 e o Predicado Z, isso de forma alguma impedirá que você tenha o Evento 1 na Sessão B com a Ação 2 e a Ação 3 sem nenhum predicado.

  • As diretivas são anexadas a sessões para controlar a utilização de buffer e expedição, e rastreamento de causalidade.

Utilização de buffer e expedição

A utilização de buffer se refere a como os dados de evento serão armazenados enquanto uma sessão de evento estiver em execução. As diretivas de utilização de buffer especificam o volume de memória a ser usado para dados de evento e a diretiva de perda para os eventos. A expedição refere-se ao tempo que os eventos permanecerão nos buffers antes de serem entregues aos destinos para processamento.

Rastreamento de causalidade

O rastreamento de causalidade proporciona capacidade para rastrear trabalho por tarefas múltiplas. Quando o rastreamento de causalidade é habilitado, cada evento disparado tem uma ID exclusiva de atividade no sistema. A ID de atividade é uma combinação de um valor GUID que permanece constante em todos os eventos de uma tarefa e um número de seqüência que é incrementado toda vez que um evento é disparado. Quando uma tarefa gera trabalho em outra, a ID de atividade da tarefa pai é enviada à tarefa filho. A tarefa filho produz a ID de atividade do pai na primeira vez dispara um evento.

A arquitetura de eventos estendidos oferece um sistema flexível que permite a utilização de diversos objetos para serem usados em conjunto na solução de problemas específicos.