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.
When you have applications and business processes relying on Azure resources, you want to monitor those resources for their availability, performance, and operation. This article describes the monitoring data generated by Media Services and how you can use the features of Azure Monitor to analyze and alert on this data.
Azure Monitor
Media Services creates monitoring data using Azure Monitor, which is a full stack monitoring service in Azure that provides a complete set of features to monitor your Azure resources in addition to resources in other clouds and on-premises.
Start with reading the article Monitoring Azure resources with Azure Monitor, which describes the following concepts:
- What is Azure Monitor?
- Costs associated with monitoring
- Monitoring data collected in Azure
- Configuring data collection
- Standard tools in Azure for analyzing and alerting on monitoring data
Media Services monitoring data
Media Services collects the same kinds of monitoring data as other Azure resources that are described in Monitoring data from Azure resources.
All data collected by Azure Monitor fits into one of two fundamental types: metrics and logs. With these two types you can:
- Visualize and analyze the metrics data using Metrics Explorer.
- Monitor Media Services diagnostic logs and create alerts and notifications for them.
- You can send or stream logs to:
- Azure Storage
- Azure Event Hubs
- Log Analytics
- Use third-party services
 
Collection and routing
Platform metrics and the Activity log are collected and stored automatically, but can be routed to other locations by using a diagnostic setting.
Resource Logs are not collected and stored until you create a diagnostic setting and route them to one or more locations.
See the article Create diagnostic setting to collect platform logs and metrics in Azure for the detailed process of creating a diagnostic setting.
Media Services metrics
Media Services metrics are collected at regular intervals whether or not the value changes.
Metric types
Metrics available for Media Services are:
- Media Services account metrics, including Key Delivery
- Live event metrics
- Streaming endpoint metrics
Analyzing metrics
You can analyze metrics for Media Services along with metrics from other Azure services using Metrics Explorer. See Getting started with Azure Metrics Explorer for details on using this tool.
Media Services logs
Activity logs
The Activity log is a platform log that provides insight into subscription-level events. You can view it independently or route it to Azure Monitor Logs, where you can do much more complex queries using Log Analytics.
Resource logs
Resource logs provide rich and frequent data about the operation of an Azure resource. For more information, see How to collect and consume log data from your Azure resources.
Media Services supports the following resource logs: Microsoft.Media/mediaservices
Media Services diagnostic logs
Some things that you can examine with diagnostic logs are:
- The number of licenses delivered by DRM type
- The number of licenses delivered by policy
- The latency on key delivery requests
- The number of unauthorized license requests from clients
Analyzing logs
Data in Azure Monitor Logs is stored in tables where each table has its own set of unique properties.
All resource logs in Azure Monitor have the same fields followed by service-specific fields. The common schema is outlined in Azure Monitor resource log schema.
Alerts
Azure Monitor alerts proactively notify you when important conditions are found in your monitoring data. They allow you to identify and address issues in your system. You can set alerts on metrics, logs, and the activity log. For more information, see Azure Monitor Alerts overview.
Schemas
For detailed description of the top-level diagnostic logs schema, see Supported services, schemas, and categories for Azure Diagnostic Logs.
Media Account Health
| Name | Description | 
|---|---|
| TimeGenerated | The timestamp (UTC) of when the event was generated. | 
| OperationName | The name of the operation that triggered the event. | 
| Level | Message level. Possible values are Informational, Warning, Error, Critical and Verbose. | 
| Location | Location of the service sending the log. | 
| EventCode | The event code. | 
| EventMessage | The event status message. | 
Key Delivery
| Name | Description | 
|---|---|
| TimeGenerated | The timestamp (UTC) of when the event was generated. | 
| OperationName | The name of the operation that triggered the event. | 
| OperationVersion | Azure Media Services operation version. | 
| ResultType | Azure Media Services operation result type. | 
| ResultSignature | Azure Media Services operation result signature. | 
| DurationMs | Azure Media Services operation duration in milliseconds. | 
| Level | Message level. Possible values are Informational, Warning, Error, Critical and Verbose. | 
| Location | Location of the service sending the log. | 
| RequestId | Id of the request. | 
| KeyType | Could be one of the following values: Clear (no encryption), FairPlay, PlayReady, or Widevine. | 
| KeyId | The ID of the requested key. | 
| TokenType | The token type. | 
| PolicyName | The Azure Resource Manager name of the policy. | 
| StatusMessage | The status message. | 
Sample key delivery log
{
    "time": "2019-01-11T17:59:10.4908614Z",
    "resourceId": "/SUBSCRIPTIONS/00000000-0000-0000-0000-0000000000/RESOURCEGROUPS/SBKEY/PROVIDERS/MICROSOFT.MEDIA/MEDIASERVICES/SBDNSTEST",
    "operationName": "MICROSOFT.MEDIA/MEDIASERVICES/CONTENTKEYS/READ",
    "operationVersion": "1.0",
    "category": "KeyDeliveryRequests",
    "resultType": "Succeeded",
    "resultSignature": "OK",
    "durationMs": 315,
    "identity": {
        "authorization": {
            "issuer": "http://testacs",
            "audience": "urn:test"
        },
        "claims": {
            "urn:microsoft:azure:mediaservices:contentkeyidentifier": "aaaaaaaa-0b0b-1c1c-2d2d-333333333333",
            "iss": "http://testacs",
            "aud": "urn:test",
            "exp": "1547233138"
        }
    },
    "level": "Informational",
    "location": "uswestcentral",
    "properties": {
        "requestId": "b0243468-d8e5-4edf-a48b-d408e1661050",
        "keyType": "Clear",
        "keyId": "aaaaaaaa-0b0b-1c1c-2d2d-333333333333",
        "policyName": "56a70229-82d0-4174-82bc-e9d3b14e5dbf",
        "tokenType": "JWT",
        "statusMessage": "OK"
    }
}
Live Events
| Name | Description | 
|---|---|
| TimeGenerated | The timestamp (UTC) when the event was generated. | 
| OperationName | The name of the operation that triggered the event. | 
| Level | Message level. Possible values are Informational, Warning, Error, Critical and Verbose. | 
| Location | Location of the service sending the event. | 
| Properties | Operation details. | 
Sample live event log
[
    {
        "TimeGenerated": "2022-10-11T06:02:13.4730825Z",
        "OperationName": "LIVEEVENTS/INGESTBEGIN",
        "Level": "Informational",
        "Location": "westcentralus",
        "Properties": {"liveEventName":"CONTOSOLIVE","streamName":"1234","remoteIP":"10.0.0.xxx","remotePort":"35091"}
    },
    {
        "TimeGenerated": "2022-10-11T06:02:19.8229491Z",
        "OperationName": "LIVEEVENTS/STREAMINFO",
        "Level": "Informational",
        "Location": "westcentralus",
        "Properties": {"liveEventName":"CONTOSOLIVE","remoteIP":"10.0.0.xxx","remotePort":"35091","trackName":"audio_160000","trackType":"audio","bitrate":160000,"timestamp":66,"timescale":1000,"resolution":"n/a"}
    },
    {
        "TimeGenerated": "2022-10-11T06:04:41.1375866Z",
        "OperationName": "LIVEEVENTS/INGESTEND",
        "Level": "Informational",
        "Location": "westcentralus",
        "Properties": {"liveEventName":"CONTOSOLIVE","streamName":"1234","remoteIP":"10.0.0.xxx","remotePort":"35091","resultCode":"MPE_CLIENT_TERMINATED_SESSION"}
    },
    {
        "TimeGenerated": "2022-10-11T06:07:01.0446756Z",
        "OperationName": "LIVEEVENTS/INGESTDISCONTINUITY",
        "Level": "Warning",
        "Location": "westcentralus",
        "Properties": {"liveEventName":"CONTOSOLIVE","trackName":"audio","timestamp":156777,"discontinuityGap":12605}
    }
]
Streaming Endpoints
| Name | Description | 
|---|---|
| TimeGenerated | The timestamp (UTC) when the event was generated. | 
| OperationName | The name of the operation that triggered the event. | 
| OperationVersion | Azure Media Services operation version. | 
| Level | Message level. Possible values are Informational, Warning, Error, Critical and Verbose. | 
| Location | Location of the service sending the event. | 
| ClientIP | IP address of the client. | 
| URL | The streaming URL from Azure Media Services. | 
| Status | Status code of the request. | 
Sample streaming endpoint log
[
    {
        "time": "2022-09-30T07:40:06.1524833Z",
        "resourceId": "/SUBSCRIPTIONS/00000000-0000-0000-0000-000000000001/RESOURCEGROUPS/CONTOSORG/PROVIDERS/MICROSOFT.MEDIA/MEDIASERVICES/CONTOSOMEDIA/STREAMINGENDPOINTS/DEFAULT",
        "operationName": "MICROSOFT.MEDIA/MEDIASERVICES/STREAMINGENDPOINTS/GET",
        "category": "StreamingEndpointRequests",
        "level": "Informational",
        "location": "uswc1",
        "properties": {
            "ClientIP": "10.0.0.1",
            "URL": "https://cdn--contosomedia-uswc.streaming.media.azure.net:443/00000000-0000-0000-0000-000000000000/contoso.ism/QualityLevels(127999)/Fragments(aac_eng_2_127999_2_1=20053333,format=mpd-time-csf)",
            "Status": "200"
        },
        "operationVersion": "1.0"
    }
]