Create an event session with an event_file target in Azure Storage
Applies to: Azure SQL Database Azure SQL Managed Instance
The high-level steps in this walkthrough are:
- Create an Azure Storage account, or find an existing suitable account to use
- Create a container in this storage account
- Create a SAS token with the required access for this container
- Create a credential to store the SAS token in the database or managed instance where you create the event session
- Create, start, and use an event session
Create a storage account and container
For a detailed description of how to create a storage account in Azure Storage, see Create a storage account. You learn how to create a storage account using Azure portal, PowerShell, Azure SQL, an ARM template, or a Bicep template.
We recommended you use an account that:
- Is a
Standard general-purpose v2
account. - Has its redundancy type matching the redundancy of the Azure SQL database, elastic pool, or managed instance where event sessions are created.
- For locally redundant Azure SQL resources, use LRS, GRS, or RA-GRS. For zone-redundant Azure SQL resources, use ZRS, GZRS, or RA-GZRS. For more information, see Azure Storage redundancy.
- Uses the
Hot
blob access tier. - Is in the same Azure region as the Azure SQL database, elastic pool, or managed instance.
Next, create a container in this storage account using Azure portal. You can also create a container using PowerShell, or using Azure CLI.
Note the names of the storage account and container you use.
Create a SAS token
The Database Engine running the event session needs specific access to the storage container. You grant this access by creating a SAS token for the container. This token must satisfy the following requirements:
- Have the
rwl
(Read
,Write
,List
) permissions - Have the start time and expiry time that encompass the lifetime of the event session
- Have no IP address restrictions
In Azure portal, find the storage account and container that you created. Select the container, and navigate to Settings > Shared access tokens. Set Permissions to Read
, Write
, List
, and set the Start and Expiry date and time. The SAS token you create only works within this time interval.
Select the Generate SAS token and URL button. The SAS token is in the Blob SAS token box. You can copy it to use in the next step.
Important
The SAS token provides read and write access to this container. Treat it as you would treat a password or any other secret.
Create a credential to store the SAS token
In Azure SQL Database, you use a database-scoped credential to store the SAS token. In Azure SQL Managed Instance, you use a server-scoped credential.
Store the SAS token in a database-scoped credential. Using a client tool such as SSMS or ADS, open a new query window, connect to the database where you create the event session, and paste the following T-SQL batch. Make sure you're connected to your user database, and not to the master
database.
Note
Executing the following T-SQL batch requires the CONTROL
database permission, which is held by the database owner (dbo
), by the members of the db_owner
database role, and by the administrator of the logical server.
/*
Create a master key to protect the secret of the credential
*/
IF NOT EXISTS (
SELECT 1
FROM sys.symmetric_keys
WHERE name = '##MS_DatabaseMasterKey##'
)
CREATE MASTER KEY;
/*
(Re-)create a database scoped credential.
The name of the credential must match the URL of the blob container.
*/
IF EXISTS (
SELECT 1
FROM sys.database_credentials
WHERE name = 'https://exampleaccount4xe.blob.core.chinacloudapi.cn/xe-example-container'
)
DROP DATABASE SCOPED CREDENTIAL [https://exampleaccount4xe.blob.core.chinacloudapi.cn/xe-example-container];
/*
The secret is the SAS token for the container. The Read, Write, and List permissions are set.
*/
CREATE DATABASE SCOPED CREDENTIAL [https://exampleaccount4xe.blob.core.chinacloudapi.cn/xe-example-container]
WITH IDENTITY = 'SHARED ACCESS SIGNATURE',
SECRET = 'sp=rwl&st=2023-10-17T23:28:32Z&se=2023-10-18T07:28:32Z&spr=https&sv=2022-11-02&sr=c&sig=REDACTED';
Before executing this batch, make the following changes:
- In all three occurrences of
https://exampleaccount4xe.blob.core.chinacloudapi.cn/xe-example-container
, replaceexampleaccount4xe
with the name of your storage account, and replacexe-example-container
with the name of your container. - Replace the entire string between the single quotes in the
SECRET
clause with the SAS token you copied in the previous step.
Create, start, and stop an Event session
Once the credential with the SAS token is created, you can create the event session. Creating an event session doesn't require the CONTROL
permission. If the credential with the correct SAS token already exists, you can create event sessions even if you have a more restricted set of permissions. See permissions for the specific permissions needed.
To create a new event session in SSMS, expand the Extended Events node. This node is under the database folder in Azure SQL Database, and under the Management folder in Azure SQL Managed Instance. Right-click on the Sessions folder, and select New Session.... On the General page, enter a name for the session, which is example-session
in this example. On the Events page, select one or more events to add to the session. In this example, we selected the sql_batch_starting
event.
On the Data Storage page, select event_file
as the target type, and paste the URL of the storage container in the Storage URL box. Type a forward slash (/
) at the end of this URL, followed by the file (blob) name. In our example, the blob name is example-session.xel
, and the entire URL is https://exampleaccount4xe.blob.core.chinacloudapi.cn/xe-example-container/example-session.xel
.
Note
For SQL Managed Instance, instead of pasting the storage container URL on the Data storage page, use the Script button to create a T-SQL script of the session. Specify the container URL as the value for the filename
argument, similar to the SQL Managed Instance example below, and execute the script to create the session.
Now that the session is configured, you can select the Script button to create a T-SQL script of the session, to save it for later. Here's the script for our example session:
CREATE EVENT SESSION [example-session] ON DATABASE
ADD EVENT sqlserver.sql_batch_starting
ADD TARGET package0.event_file(SET filename=N'https://exampleaccount4xe.blob.core.chinacloudapi.cn/xe-example-container/example-session.xel')
GO
Select OK to create the session.
In Object Explorer, expand the Sessions folder to see the event session you created. By default, the session isn't started when it's created. To start the session, right-click on the session name, and select Start Session. You can later stop it by similarly selecting Stop Session, once the session is running.
As T-SQL batches are executed in this database or managed instance, the session writes events to the example-session.xel
blob in the xe-example-container
storage container.
To stop the session, right-click it in Object Explorer, and select Stop Session.
View event data
You can view event data in the SQL Server Management Studio (SSMS) event viewer UI, where you can use filters and aggregations to analyze the data you captured. For more information on using the event viewer in SSMS, see View event data in SSMS.
Download xel files from Azure storage
Tip
If you use SSMS v19.2 or later, you do not need to download xel
files as described in this section. In these versions, SSMS reads the xel
files for each session directly from Azure storage. For more information, see the Improving Extended Events in Azure SQL blog.
Download the xel
blob for the session from the storage container and save it as a local file. In Azure portal, find the storage account you used, select Containers under Data storage, and select the container you created for your event session. The blob for the session has the session name as the first part of its name, with a numeric suffix. Select the ellipsis (...) to show the context menu for the blob, and select Download.
You can install Azure Storage Explorer to download multiple xel
blobs in one operation.
Once the xel
file is downloaded, open it in SSMS. On the SSMS main menu, go to File and select Open. If you have a single xel
file, select File... and browse to the file you downloaded. If you have multiple xel
files generated by the same event session (known as rollover files), you can use the Merge Extended Event Files... dialog to open all of them in the event viewer.
View event data using T-SQL
To read event session data using T-SQL, use the sys.fn_xe_file_target_read_file() function. To use this function in a database or managed instance different from the one where the event session is created, create a credential to give the Database Engine access to the storage container with the event blobs.
For a more detailed walkthrough, see Create an event session in SSMS.