Panoramica degli eventi estesi

Si applica a:SQL ServerDatabase SQL di AzureIstanza gestita di SQL di Azure

L'architettura degli Eventi estesi (XEvents) consente agli utenti di raccogliere la quantità di dati necessaria per monitorare, identificare o risolvere i problemi relativi alle prestazioni in SQL Server, database SQL di Azure e Istanza gestita di SQL di Azure. Eventi estesi è altamente configurabile, leggero e facilmente scalabile. Per altre informazioni, vedere Architettura degli Eventi estesi.

Gli Eventi estesi sostituiscono le funzionalità deprecate di Analisi SQL e SQL Server Profiler.

Per iniziare a usare gli Eventi estesi, usare Avvio rapido: Eventi estesi.

Vantaggi degli eventi estesi di

Gli Eventi estesi sono un sistema di monitoraggio delle prestazioni leggero che usa risorse di sistema minime, fornendo al tempo stesso una visualizzazione dettagliata e approfondita del motore di database. SQL Server Management Studio fornisce un'interfaccia utente grafica per gli eventi estesi per creare, modificare ed eliminare sessioni di eventi e per visualizzare e analizzare i dati della sessione. Per altre informazioni sul supporto degli Eventi estesi in Management Studio, vedere:

Concetti degli Eventi estesi

Eventi estesi è basato su concetti esistenti di Event Tracing for Windows, ad esempio un evento o un consumer eventi e introduce concetti nuovi come azione e predicato.

Nella seguente tabella vengono forniti riferimenti alla documentazione per comprendere i concetti in Eventi estesi.

Articolo Descrizione
Pacchetti degli Eventi estesi Descrive i pacchetti di Eventi estesi che contengono oggetti. Questi oggetti vengono usati per ottenere ed elaborare dati durante l'esecuzione di una sessione di Eventi estesi.
Destinazioni degli Eventi estesi Vengono descritti i consumer di eventi che possono ricevere dati durante una sessione dell'evento.
Motore degli Eventi estesi Viene descritto il motore che implementa e gestisce una sessione degli eventi estesi.
Sessioni degli Eventi estesi Viene descritta la sessione Eventi estesi.

Architettura degli Eventi estesi

Eventi estesi è il nome di un sistema generale di gestione degli eventi per sistemi server. L'infrastruttura degli eventi estesi supporta la correlazione di dati dal motore di database e in certe condizioni, la correlazione di dati dal sistema operativo e dalle applicazioni di database. Nel caso del sistema operativo, l'output di Eventi estesi deve essere indirizzato a Event Tracing for Windows (ETW). ETW consente di correlare i dati di un evento con i dati di un evento del sistema operativo o di un'applicazione.

In tutte le applicazioni sono presenti punti di esecuzione utili sia all'interno che all'esterno di un'applicazione. All'interno dell'applicazione, l'elaborazione asincrona può essere accodata utilizzando informazioni raccolte durante l'esecuzione iniziale di un'attività. All'esterno dell'applicazione, i punti di esecuzione forniscono utilità di monitoraggio con informazioni. Le informazioni sono relative alle caratteristiche del comportamento e delle prestazioni dell'applicazione monitorata.

Gli eventi estesi supportano l'utilizzo di dati degli eventi all'esterno di un processo. In genere, questi dati vengono usati dagli utenti che amministrano o supportano un prodotto eseguendo il monitoraggio delle prestazioni o sviluppando applicazioni in un prodotto a scopo di debug. I dati vengono utilizzati o analizzati usando strumenti come SQL Server Management Studio, profiler XEvent e Monitor prestazioni e T-SQL o gli strumenti da riga di comando di Windows.

Gli aspetti chiave della progettazione degli eventi estesi sono i seguenti:

  • Il motore degli eventi estesi è agnostico in termini di eventi. Il motore riesce ad associare qualsiasi evento a qualsiasi destinazione, perché il motore non è vincolato al contenuto dell'evento. Per ulteriori informazioni sul motore degli eventi estesi, vedere Motore degli Eventi estesi.
  • Gli eventi sono separati dai consumer di eventi chiamati destinazioni negli eventi estesi. Ciò significa che qualsiasi destinazione può ricevere qualsiasi evento. Inoltre, qualsiasi evento generato può essere utilizzato automaticamente dalla destinazione, che può scrivere nel log o fornire un contesto dell'evento supplementare. Per ulteriori informazioni, vedere Destinazioni per gli Eventi estesi.
  • Gli eventi sono distinti dall'azione da intraprendere quando un evento si verifica. Di conseguenza, qualsiasi azione può essere associata a qualsiasi evento.
  • I predicati consentono di filtrare dinamicamente i casi in cui i dati degli eventi devono essere acquisiti. Il filtro dinamico garantisce maggiore flessibilità per l'infrastruttura di Eventi estesi. Per altre informazioni, vedere Pacchetti degli Eventi estesi.

Gli eventi estesi possono generare in modo sincrono dati degli eventi (e in modo asincrono elaborare tali dati), il che fornisce una soluzione flessibile per la gestione degli eventi. Inoltre, gli eventi estesi forniscono le funzionalità seguenti:

  • Approccio unificato alla gestione degli eventi nel sistema server, consentendo agli utenti di isolare eventi specifici ai fini della risoluzione dei problemi.
  • Supporto e integrazione con gli strumenti ETW esistenti.
  • Meccanismo di gestione degli eventi interamente configurabile che usa Transact-SQL.
  • Possibilità di monitorare dinamicamente i processi attivi, con un impatto minimo su tali processi.
  • Sessione di integrità di sistema predefinita che viene eseguita senza effetti visibili sulle prestazioni. Tale sessione consente di raccogliere dati di sistema che è possibile utilizzare per risolvere i problemi relativi alle prestazioni. Per altre informazioni, vedere Utilizzare la sessione system_health.

Attività degli eventi estesi

L'utilizzo di Management Studio o Transact-SQL per eseguire istruzioni Transact-SQL Data Definition Language (DDL), utilizzare DMV e funzioni o viste del catalogo consente di creare soluzioni per la risoluzione dei problemi relativi agli Eventi estesi di SQL Server semplici o complesse per l'ambiente SQL Server.

Descrizione attività Articolo
Utilizzare Esplora oggetti per gestire sessioni di eventi. Gestire sessioni di eventi in Esplora oggetti
Viene descritto come creare una sessione di eventi estesi. Sessioni degli Eventi estesi
Viene descritto come visualizzare e aggiornare i dati di destinazione. Vedere dati degli eventi in SQL Server Management Studio
Viene descritto come utilizzare gli strumenti degli eventi estesi per creare e gestire sessioni di eventi estesi di . Strumenti degli eventi estesi
Viene descritto come alterare una sessione Eventi estesi. Modificare una sessione Eventi estesi
Viene descritto come ottenere informazioni sui campi associati agli eventi. Recuperare i campi per tutti gli eventi
Viene descritto come individuare gli eventi disponibili nei pacchetti registrati. Istruzioni SELECT e JOIN da viste di sistema per eventi estesi in SQL Server
Viene descritto come individuare le destinazioni degli eventi estesi disponibili nei pacchetti registrati. Destinazioni degli Eventi estesi
Viene descritto come visualizzare gli eventi e le azioni Eventi estesi equivalenti a ogni evento di Traccia SQL e alle colonne associate. Visualizzare gli eventi estesi equivalenti alle classi di eventi di Traccia SQL
Descrive come trovare i parametri che è possibile impostare quando si usa la clausola ADD TARGET nelle istruzioni CREATE EVENT SESSION o ALTER EVENT SESSION. Destinazioni degli Eventi estesi
Viene descritto come convertire uno script di Traccia SQL esistente in una sessione Eventi estesi. Convertire uno script di Traccia SQL esistente in una sessione Eventi estesi
Viene descritto come determinare quali query mantengono il blocco, il piano della query e lo stack Transact-SQL al momento del blocco. Individuare le query che mantengono attivi i blocchi
Descrive come identificare l'origine dei blocchi. Cercare gli oggetti con il maggior numero di blocchi acquisiti
Viene illustrato come utilizzare gli eventi estesi con Analisi eventi per Windows al fine di monitorare l'attività del sistema. Monitorare l'attività del sistema mediante gli eventi estesi
Uso delle viste catalogo e delle DMV per gli Eventi estesi Istruzioni SELECT e JOIN da viste di sistema per eventi estesi in SQL Server

Usare la query T-SQL seguente per elencare tutti i possibili Eventi estesi e le relative descrizioni:

SELECT obj1.name AS [XEvent-name],
    col2.name AS [XEvent-column],
    obj1.description AS [Descr-name],
    col2.description AS [Descr-column]
FROM sys.dm_xe_objects AS obj1
INNER JOIN sys.dm_xe_object_columns AS col2
    ON col2.object_name = obj1.name
ORDER BY obj1.name,
    col2.name

Gli esempi di codice per il database SQL di Azure e Istanza gestita di SQL possono essere diversi

Alcuni esempi di codice Transact-SQL scritti per SQL Server richiedono qualche piccola modifica per funzionare in Azure. Una categoria di tali esempi di codice prevede viste del catalogo i cui prefissi del nome differiscono a seconda del tipo di motore di database:

  • server_ - prefisso per SQL Server e Istanza gestita di SQL di Azure
  • database_ - prefisso per il database SQL di Azure e Istanza gestita di SQL

Database SQL di Azure supporta solo sessioni di eventi con ambito database. SQL Server Management Studio (SSMS) supporta completamente le sessioni di eventi con ambito database per il database SQL di Azure: un nodo Eventi estesi contenente sessioni con ambito database viene visualizzato in ogni database in Esplora oggetti.

Istanza gestita di SQL di Azure supporta sia sessioni con ambito database che sessioni con ambito server. SSMS supporta completamente le sessioni con ambito server per Istanza gestita di SQL: un nodo Eventi estesi contenente tutte le sessioni con ambito server viene visualizzato nella cartella Gestione per ogni istanza gestita in Esplora oggetti.

Nota

Le sessioni con ambito server sono consigliate per le istanze gestite. Le sessioni con ambito database non vengono visualizzate in Esplora oggetti in SSMS per Istanza gestita di SQL di Azure. Le sessioni con ambito database possono essere sottoposte a query e gestite solo con Transact-SQL quando si usa un'istanza gestita.

Come riferimento visivo, la tabella seguente elenca e confronta due subset delle viste di catalogo. Per brevità, i subset sono limitati ai nomi di vista che contengono anche la stringa _event. I subset hanno prefissi di nome diversi perché supportano diversi tipi di motori di database.

Nome in SQL Server e Istanza gestita di SQL di Azure Nome nel database SQL di Azure e Istanza gestita di SQL di Azure
server_event_notifications
server_event_session_actions
server_event_session_events
server_event_session_fields
server_event_session_targets
server_event_sessions
server_events
server_trigger_events
database_event_session_actions
database_event_session_events
database_event_session_fields
database_event_session_targets
database_event_sessions

I due elenchi nella tabella precedente sono stati aggiornati al mese di marzo 2022. Per un elenco aggiornato, eseguire l'istruzione SELECT Transact-SQL seguente:

SELECT name
    FROM sys.all_objects
    WHERE
        (name LIKE 'database[_]%' OR
         name LIKE 'server[_]%' )
        AND name LIKE '%[_]event%'
        AND type = 'V'
        AND SCHEMA_NAME(schema_id) = 'sys'
    ORDER BY name;