CDK Constructs for AWS CloudWatch
Project description
Amazon CloudWatch Construct Library
---Metric objects
Metric objects represent a metric that is emitted by AWS services or your own
application, such as CPUUsage, FailureCount or Bandwidth.
Metric objects can be constructed directly or are exposed by resources as
attributes. Resources that expose metrics will have functions that look
like metricXxx() which will return a Metric object, initialized with defaults
that make sense.
For example, lambda.Function objects have the fn.metricErrors() method, which
represents the amount of errors reported by that Lambda function:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
errors = fn.metric_errors()
Instantiating a new Metric object
If you want to reference a metric that is not yet exposed by an existing construct,
you can instantiate a Metric object to represent it. For example:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
metric = Metric(
namespace="MyNamespace",
metric_name="MyMetric",
dimensions={
"ProcessingStep": "Download"
}
)
Metric Math
Math expressions are supported by instantiating the MathExpression class.
For example, a math expression that sums two other metrics looks like this:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
all_problems = MathExpression(
expression="errors + faults",
using_metrics={
"errors": my_construct.metric_errors(),
"faults": my_construct.metric_faults()
}
)
You can use MathExpression objects like any other metric, including using
them in other math expressions:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
problem_percentage = MathExpression(
expression="(problems / invocations) * 100",
using_metrics={
"problems": all_problems,
"invocations": my_construct.metric_invocations()
}
)
Aggregation
To graph or alarm on metrics you must aggregate them first, using a function
like Average or a percentile function like P99. By default, most Metric objects
returned by CDK libraries will be configured as Average over 300 seconds (5 minutes).
The exception is if the metric represents a count of discrete events, such as
failures. In that case, the Metric object will be configured as Sum over 300 seconds, i.e. it represents the number of times that event occurred over the
time period.
If you want to change the default aggregation of the Metric object (for example, the function or the period), you can do so by passing additional parameters to the metric function call:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
minute_error_rate = fn.metric_errors(
statistic="avg",
period=Duration.minutes(1),
label="Lambda failure rate"
)
This function also allows changing the metric label or color (which will be useful when embedding them in graphs, see below).
Rates versus Sums
The reason for using
Sumto count discrete events is that some events are emitted as either0or1(for exampleErrorsfor a Lambda) and some are only emitted as1(for exampleNumberOfMessagesPublishedfor an SNS topic).In case
0-metrics are emitted, it makes sense to take theAverageof this metric: the result will be the fraction of errors over all executions.If
0-metrics are not emitted, theAveragewill always be equal to1, and not be very useful.In order to simplify the mental model of
Metricobjects, we default to aggregating usingSum, which will be the same for both metrics types. If you happen to know the Metric you want to alarm on makes sense as a rate (Average) you can always choose to change the statistic.
Alarms
Alarms can be created on metrics in one of two ways. Either create an Alarm
object, passing the Metric object to set the alarm on:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
Alarm(self, "Alarm",
metric=fn.metric_errors(),
threshold=100,
evaluation_periods=2
)
Alternatively, you can call metric.createAlarm():
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
fn.metric_errors().create_alarm(self, "Alarm",
threshold=100,
evaluation_periods=2
)
The most important properties to set while creating an Alarms are:
threshold: the value to compare the metric against.comparisonOperator: the comparison operation to use, defaults tometric >= threshold.evaluationPeriods: how many consecutive periods the metric has to be breaching the the threshold for the alarm to trigger.
Alarm Actions
To add actions to an alarm, use the integration classes from the
@aws-cdk/aws-cloudwatch-actions package. For example, to post a message to
an SNS topic when an alarm breaches, do the following:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
import aws_cdk.aws_cloudwatch_actions as cw_actions
# ...
topic = sns.Topic(stack, "Topic")
alarm = cloudwatch.Alarm(stack, "Alarm")
alarm.add_alarm_action(cw_actions.SnsAction(topic))
A note on units
In CloudWatch, Metrics datums are emitted with units, such as seconds or
bytes. When Metric objects are given a unit attribute, it will be used to
filter the stream of metric datums for datums emitted using the same unit
attribute.
In particular, the unit field is not used to rescale datums or alarm threshold
values (for example, it cannot be used to specify an alarm threshold in
Megabytes if the metric stream is being emitted as bytes).
You almost certainly don't want to specify the unit property when creating
Metric objects (which will retrieve all datums regardless of their unit),
unless you have very specific requirements. Note that in any case, CloudWatch
only supports filtering by unit for Alarms, not in Dashboard graphs.
Please see the following GitHub issue for a discussion on real unit calculations in CDK: https://github.com/aws/aws-cdk/issues/5595
Dashboards
Dashboards are set of Widgets stored server-side which can be accessed quickly from the AWS console. Available widgets are graphs of a metric over time, the current value of a metric, or a static piece of Markdown which explains what the graphs mean.
The following widgets are available:
GraphWidget-- shows any number of metrics on both the left and right vertical axes.AlarmWidget-- shows the graph and alarm line for a single alarm.SingleValueWidget-- shows the current value of a set of metrics.TextWidget-- shows some static Markdown.
Graph widget
A graph widget can display any number of metrics on either the left or
right vertical axis:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
dashboard.add_widgets(GraphWidget(
title="Executions vs error rate",
left=[execution_count_metric],
right=[error_count_metric.with(
statistic="average",
label="Error rate",
color=Color.GREEN
)]
))
Graph widgets can also display annotations attached to the left or the right y-axis.
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
dashboard.add_widgets(GraphWidget(
# ...
# ...
left_annotations=[{"value": 1800, "label": Duration.minutes(30).to_human_string(), "color": Color.RED}, {"value": 3600, "label": "1 hour", "color": "#2ca02c"}
]
))
Alarm widget
An alarm widget shows the graph and the alarm line of a single alarm:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
dashboard.add_widgets(AlarmWidget(
title="Errors",
alarm=error_alarm
))
Single value widget
A single-value widget shows the latest value of a set of metrics (as opposed to a graph of the value over time):
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
dashboard.add_widgets(SingleValueWidget(
metrics=[visitor_count, purchase_count]
))
Text widget
A text widget shows an arbitrary piece of MarkDown. Use this to add explanations to your dashboard:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
dashboard.add_widgets(TextWidget(
markdown="# Key Performance Indicators"
))
Dashboard Layout
The widgets on a dashboard are visually laid out in a grid that is 24 columns wide. Normally you specify X and Y coordinates for the widgets on a Dashboard, but because this is inconvenient to do manually, the library contains a simple layout system to help you lay out your dashboards the way you want them to.
Widgets have a width and height property, and they will be automatically
laid out either horizontally or vertically stacked to fill out the available
space.
Widgets are added to a Dashboard by calling add(widget1, widget2, ...).
Widgets given in the same call will be laid out horizontally. Widgets given
in different calls will be laid out vertically. To make more complex layouts,
you can use the following widgets to pack widgets together in different ways:
Column: stack two or more widgets vertically.Row: lay out two or more widgets horizontally.Spacer: take up empty space
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file aws-cdk.aws-cloudwatch-1.31.0.tar.gz.
File metadata
- Download URL: aws-cdk.aws-cloudwatch-1.31.0.tar.gz
- Upload date:
- Size: 192.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/39.0.1 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.6.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d97664e86dbaa6c35479a29b7126ad8fef3103cab40ac5951cdeb46a193ee016
|
|
| MD5 |
6cc8277aa6d0d9ececc24ea56151ea7f
|
|
| BLAKE2b-256 |
d071b81fde07811f5690a1844280ab34b954e3fce3b3ce42959dfc89268ba4b5
|
File details
Details for the file aws_cdk.aws_cloudwatch-1.31.0-py3-none-any.whl.
File metadata
- Download URL: aws_cdk.aws_cloudwatch-1.31.0-py3-none-any.whl
- Upload date:
- Size: 190.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/39.0.1 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.6.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dda2ac933cf631dd9c115cf8c5e7e41d6eb9635fd86f75fc6a36dad419ffaf36
|
|
| MD5 |
ab889e4f25ae9d7ce29c900088b595ec
|
|
| BLAKE2b-256 |
b95203f2ecc680bac6df00d93cf2c4ab5890a55248999e53f02b354055faf3b9
|