Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
The Fabric Apache Spark diagnostic emitter extension is a library that enables Apache Spark applications to emit logs, event logs, and metrics to multiple destinations, including Azure Log Analytics, Azure Storage, and Azure Event Hubs.
In this tutorial, you learn how to use the Fabric Apache Spark diagnostic emitter extension to send Apache Spark application logs, event logs, and metrics to your Azure Storage account.
Collect logs and metrics to storage account
Step 1: Create a storage account
To collect diagnostic logs and metrics, you can use an existing Azure Storage account. If you don't have one, you can create an Azure blob storage account or create a storage account to use with Azure Data Lake Storage Gen2.
Step 2: Create a Fabric Environment Artifact with Apache Spark Configuration
Option 1: Configure with Azure Storage URI and Access key
- Create a Fabric Environment Artifact in Fabric 
- Add the following Spark properties with the appropriate values to the environment artifact, or select Add from .yml in the ribbon to download the sample yaml file, which already containing the following properties. - spark.synapse.diagnostic.emitters: MyStorageBlob spark.synapse.diagnostic.emitter.MyStorageBlob.type: "AzureStorage" spark.synapse.diagnostic.emitter.MyStorageBlob.categories: "DriverLog,ExecutorLog,EventLog,Metrics" spark.synapse.diagnostic.emitter.MyStorageBlob.uri: "https://<my-blob-storage>.blob.core.windows.net/<container-name>/<folder-name>" spark.synapse.diagnostic.emitter.MyStorageBlob.auth: "AccessKey" spark.synapse.diagnostic.emitter.MyStorageBlob.secret: <storage-access-key> spark.fabric.pools.skipStarterPools: "true" //Add this Spark property when using the default pool.- Fill in the following parameters in the configuration file: - <my-blob-storage>,- <container-name>,- <folder-name>,- <storage-access-key>. For more details on these parameters, see Azure Storage configurations.
Option 2: Configure with Azure Key Vault
Note
Ensure that users who submit Apache Spark applications are granted read secret permissions. For more information, see Provide access to Key Vault keys, certificates, and secrets with an Azure role-based access control.
To configure Azure Key Vault for storing the workspace key:
- Create and go to your key vault in the Azure portal. 
- On the settings page for the key vault, select Secrets, then Generate/Import. 
- On the Create a secret screen, choose the following values: - Name: Enter a name for the secret.
- Value: Enter the <storage-access-key>for the secret.
- Leave the other values to their defaults. Then select Create.
 
- Create a Fabric Environment Artifact in Fabric. 
- Add the following Spark properties. Or select Add from .yml on the ribbon to upload the sample yaml file which includes following Spark properties. - spark.synapse.diagnostic.emitters: <MyStorageBlob> spark.synapse.diagnostic.emitter.MyStorageBlob.type: "AzureStorage" spark.synapse.diagnostic.emitter.MyStorageBlob.categories: "DriverLog,ExecutorLog,EventLog,Metrics" spark.synapse.diagnostic.emitter.MyStorageBlob.uri: "https://<my-blob-storage>.blob.core.windows.net/<container-name>/<folder-name>" spark.synapse.diagnostic.emitter.MyStorageBlob.auth: "AccessKey" spark.synapse.diagnostic.emitter.MyStorageBlob.secret.keyVault: <AZURE_KEY_VAULT_URI> spark.synapse.diagnostic.emitter.MyStorageBlob.secret.keyVault.secretName: <AZURE_KEY_VAULT_SECRET_KEY_NAME> spark.fabric.pools.skipStarterPools: "true" //Add this Spark property when using the default pool.- Fill in the following parameters in the configuration file: - <my-blob-storage>,- <container-name>,- <folder-name>,- <AZURE_KEY_VAULT_URI>,- <AZURE_KEY_VAULT_SECRET_KEY_NAME>. For more details on these parameters, see Azure Storage configurations.
- Save and publish changes. 
Step 3: Attach the environment artifact to notebooks or spark job definitions, or set it as the workspace default
Note
Only workspace admins can designate an environment as the default for a workspace.
Once set, it becomes the default environment for all notebooks and Spark job definitions within the workspace. For more details, see Fabric Workspace Settings.
To attach the environment to Notebooks or Spark job definitions:
- Navigate to the specific notebook or Spark job definition in Fabric.
- Select the Environment menu on the Home tab and select the environment with the configured diagnostics Spark properties.
- The configuration is applied when you start a Spark session.
To set the environment as the workspace default:
- Navigate to Workspace Settings in Fabric.
- Find the Spark settings in your Workspace settings (Workspace setting -> Data Engineering/Science -> Spark settings).
- Select Environment tab and choose the environment with diagnostics spark properties configured, and click Save.
Step 4: View the logs files in Azure storage account
After submitting a job to the configured Spark session, you can view the logs and metrics files in the destination storage account. The logs are stored in corresponding paths based on different applications, identified by <workspaceId>.<fabricLivyId>. All log files are in JSON Lines format (also known as newline-delimited JSON or ndjson), which is convenient for data processing.
Available configurations
| Configuration | Description | 
|---|---|
| spark.synapse.diagnostic.emitters | Required. The comma-separated destination names of diagnostic emitters. For example, MyDest1,MyDest2 | 
| spark.synapse.diagnostic.emitter.<destination>.type | Required. Built-in destination type. To enable Azure storage destination, AzureStorageneeds to be included in this field. | 
| spark.synapse.diagnostic.emitter.<destination>.categories | Optional. The comma-separated selected log categories. Available values include DriverLog,ExecutorLog,EventLog,Metrics. If not set, the default value is all categories. | 
| spark.synapse.diagnostic.emitter.<destination>.auth | Required. AccessKeyfor using storage account access key authorization.SASfor shared access signatures authorization. | 
| spark.synapse.diagnostic.emitter.<destination>.uri | Required. The destination blob container folder uri. Should match pattern https://<my-blob-storage>.blob.core.windows.net/<container-name>/<folder-name>. | 
| spark.synapse.diagnostic.emitter.<destination>.secret | Optional. The secret (AccessKey or SAS) content. | 
| spark.synapse.diagnostic.emitter.<destination>.secret.keyVault | Required if .secretisn't specified. The Azure Key vault uri where the secret (AccessKey or SAS) is stored. | 
| spark.synapse.diagnostic.emitter.<destination>.secret.keyVault.secretName | Required if .secret.keyVaultis specified. The Azure Key vault secret name where the secret (AccessKey or SAS) is stored. | 
| spark.synapse.diagnostic.emitter.<destination>.filter.eventName.match | Optional. The comma-separated spark event names, you can specify which events to collect. For example: SparkListenerApplicationStart,SparkListenerApplicationEnd | 
| spark.synapse.diagnostic.emitter.<destination>.filter.loggerName.match | Optional. The comma-separated Log4j logger names, you can specify which logs to collect. For example: org.apache.spark.SparkContext,org.example.Logger | 
| spark.synapse.diagnostic.emitter.<destination>.filter.metricName.match | Optional. The comma-separated spark metric name suffixes, you can specify which metrics to collect. For example: jvm.heap.used | 
| spark.fabric.pools.skipStarterPools | Required. This Spark property is used to force an on-demand Spark session. You should set the value to truewhen using the default pool in order to trigger the libraries to emit logs and metrics. | 
Log data sample
Here's a sample log record in JSON format:
{
  "timestamp": "2025-02-28T09:13:57.978Z",
  "category": "Log|EventLog|Metrics",
  "fabricLivyId": "<fabric-livy-id>",
  "applicationId": "<application-id>",
  "applicationName": "<application-name>",
  "executorId": "<driver-or-executor-id>",
  "userId": "<the-submitter-user-id>",
  "fabricTenantId": "<my-fabric-tenant-id>",
  "capacityId": "<my-fabric-capacity-id>",
  "artifactType": "SynapseNotebook|SparkJobDefinition",
  "artifactId": "<my-fabric-artifact-id>",
  "fabricWorkspaceId": "<my-fabric-workspace-id>",
  "fabricEnvId": "<my-fabric-environment-id>",
  "executorMin": "<executor-min>",
  "executorMax": "<executor-max>",
  "isHighConcurrencyEnabled": "true|false",
  "properties": {
    // The message properties of logs, events and metrics.
    "timestamp": "2025-02-28T09:13:57.941Z",
    "message": "ApplicationAttemptId: appattempt_1740734011890_0001_000001",
    "logger_name": "org.apache.spark.deploy.yarn.ApplicationMaster",
    "level": "INFO",
    "thread_name": "main"
    // ...
  }
}
Fabric workspaces with Managed virtual network
Create a managed private endpoint for the target Azure Blob Storage. For detailed instructions, refer to Create and use managed private endpoints in Microsoft Fabric - Microsoft Fabric.
Once the managed private endpoint is approved, users can begin emitting logs and metrics to the target Azure Blob Storage.