AWS::RUM::AppMonitor MetricDefinition - AWS CloudFormation

AWS::RUM::AppMonitor MetricDefinition

Specifies one custom metric or extended metric that you want the CloudWatch RUM app monitor to send to a destination. Valid destinations include CloudWatch and Evidently.

By default, RUM app monitors send some metrics to CloudWatch. These default metrics are listed in CloudWatch metrics that you can collect.

In addition to these default metrics, you can choose to send extended metrics or custom metrics or both.

  • Extended metrics enable you to send metrics with additional dimensions not included in the default metrics. You can also send extended metrics to Evidently as well as CloudWatch. The valid dimension names for the additional dimensions for extended metrics are BrowserName, CountryCode, DeviceType, FileType, OSName, and PageId. For more information, see Extended metrics.

  • Custom metrics are metrics that you define. You can send custom metrics to CloudWatch or to CloudWatch Evidently or to both. With custom metrics, you can use any metric name and namespace, and to derive the metrics you can use any custom events, built-in events, custom attributes, or default attributes.

    You can't send custom metrics to the AWS/RUM namespace. You must send custom metrics to a custom namespace that you define. The namespace that you use can't start with AWS/. CloudWatch RUM prepends RUM/CustomMetrics/ to the custom namespace that you define, so the final namespace for your metrics in CloudWatch is RUM/CustomMetrics/your-custom-namespace .

For information about syntax rules for specifying custom metrics and extended metrics, see MetridDefinitionRequest in the CloudWatch RUM API Reference.

The maximum number of metric definitions that one destination can contain is 2000.

Extended metrics sent to CloudWatch and RUM custom metrics are charged as CloudWatch custom metrics. Each combination of additional dimension name and dimension value counts as a custom metric.

If some metric definitions that you specify are not valid, then the operation will not modify any metric definitions even if other metric definitions specified are valid.

Syntax

To declare this entity in your AWS CloudFormation template, use the following syntax:

JSON

{ "DimensionKeys" : {Key: Value, ...}, "EventPattern" : String, "Name" : String, "Namespace" : String, "UnitLabel" : String, "ValueKey" : String }

YAML

DimensionKeys: Key: Value EventPattern: String Name: String Namespace: String UnitLabel: String ValueKey: String

Properties

DimensionKeys

This field is a map of field paths to dimension names. It defines the dimensions to associate with this metric in CloudWatch. The value of this field is used only if the metric destination is CloudWatch. If the metric destination is Evidently, the value of DimensionKeys is ignored.

Required: No

Type: Object of String

Pattern: ^(?!:).*[^\s].*

Minimum: 1

Maximum: 255

Update requires: No interruption

EventPattern

The pattern that defines the metric. RUM checks events that happen in a user's session against the pattern, and events that match the pattern are sent to the metric destination.

If the metrics destination is CloudWatch and the event also matches a value in DimensionKeys, then the metric is published with the specified dimensions.

Required: No

Type: String

Minimum: 1

Maximum: 4000

Update requires: No interruption

Name

The name of the metric that is defined in this structure.

Required: Yes

Type: String

Minimum: 1

Maximum: 255

Update requires: No interruption

Namespace

If you are creating a custom metric instead of an extended metrics, use this parameter to define the metric namespace for that custom metric. Do not specify this parameter if you are creating an extended metric.

You can't use any string that starts with AWS/ for your namespace.

Required: No

Type: String

Pattern: [a-zA-Z0-9-._/#:]+$

Minimum: 1

Maximum: 237

Update requires: No interruption

UnitLabel

Use this field only if you are sending this metric to CloudWatch. It defines the CloudWatch metric unit that this metric is measured in.

Required: No

Type: String

Minimum: 1

Maximum: 256

Update requires: No interruption

ValueKey

The field within the event object that the metric value is sourced from.

Required: No

Type: String

Pattern: .*

Minimum: 1

Maximum: 256

Update requires: No interruption