The CDK Construct Library for AWS::Synthetics
Project description
Amazon CloudWatch Synthetics Construct Library
---All classes with the
Cfnprefix in this module (CFN Resources) are always stable and safe to use.
The APIs of higher level constructs in this module are in developer preview before they become stable. We will only make breaking changes to address unforeseen API issues. Therefore, these APIs are not subject to Semantic Versioning, and breaking changes will be announced in release notes. This means that while you may use them, you may need to update your source code when upgrading to a newer version of this package.
Amazon CloudWatch Synthetics allow you to monitor your application by generating synthetic traffic. The traffic is produced by a canary: a configurable script that runs on a schedule. You configure the canary script to follow the same routes and perform the same actions as a user, which allows you to continually verify your user experience even when you don't have any traffic on your applications.
Canary
To illustrate how to use a canary, assume your application defines the following endpoint:
% curl "https://api.example.com/user/books/topbook/"
The Hitchhikers Guide to the Galaxy
The below code defines a canary that will hit the books/topbook endpoint every 5 minutes:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
import aws_cdk.aws_synthetics as synthetics
canary = synthetics.Canary(self, "MyCanary",
schedule=synthetics.Schedule.rate(Duration.minutes(5)),
test=Test.custom(
code=synthetics.Code.from_asset(path.join(__dirname, "canary")),
handler="index.handler"
),
runtime=synthetics.Runtime.SYNTHETICS_NODEJS_PUPPETEER_3_0
)
The following is an example of an index.js file which exports the handler function:
var synthetics = require('Synthetics');
const log = require('SyntheticsLogger');
const pageLoadBlueprint = async function () {
// INSERT URL here
const URL = "https://api.example.com/user/books/topbook/";
let page = await synthetics.getPage();
const response = await page.goto(URL, {waitUntil: 'domcontentloaded', timeout: 30000});
//Wait for page to render.
//Increase or decrease wait time based on endpoint being monitored.
await page.waitFor(15000);
// This will take a screenshot that will be included in test output artifacts
await synthetics.takeScreenshot('loaded', 'loaded');
let pageTitle = await page.title();
log.info('Page title: ' + pageTitle);
if (response.status() !== 200) {
throw "Failed to load page!";
}
};
exports.handler = async () => {
return await pageLoadBlueprint();
};
Note: The function must be called
handler.
The canary will automatically produce a CloudWatch Dashboard:
The Canary code will be executed in a lambda function created by Synthetics on your behalf. The Lambda function includes a custom runtime provided by Synthetics. The provided runtime includes a variety of handy tools such as Puppeteer (for nodejs based one) and Chromium.
To learn more about Synthetics capabilities, check out the docs.
Configuring the Canary Script
To configure the script the canary executes, use the test property. The test property accepts a Test instance that can be initialized by the Test class static methods. Currently, the only implemented method is Test.custom(), which allows you to bring your own code. In the future, other methods will be added. Test.custom() accepts code and handler properties -- both are required by Synthetics to create a lambda function on your behalf.
The synthetics.Code class exposes static methods to bundle your code artifacts:
code.fromInline(code)- specify an inline script.code.fromAsset(path)- specify a .zip file or a directory in the local filesystem which will be zipped and uploaded to S3 on deployment. See the above Note for directory structure.code.fromBucket(bucket, key[, objectVersion])- specify an S3 object that contains the .zip file of your runtime code. See the above Note for directory structure.
Using the Code class static initializers:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
# To supply the code inline:
canary = Canary(self, "MyCanary",
test=Test.custom(
code=synthetics.Code.from_inline("/* Synthetics handler code */"),
handler="index.handler"
),
runtime=synthetics.Runtime.SYNTHETICS_NODEJS_PUPPETEER_3_0
)
# To supply the code from your local filesystem:
canary = Canary(self, "MyCanary",
test=Test.custom(
code=synthetics.Code.from_asset(path.join(__dirname, "canary")),
handler="index.handler"
),
runtime=synthetics.Runtime.SYNTHETICS_NODEJS_PUPPETEER_3_0
)
# To supply the code from a S3 bucket:
canary = Canary(self, "MyCanary",
test=Test.custom(
code=synthetics.Code.from_bucket(bucket, "canary.zip"),
handler="index.handler"
),
runtime=synthetics.Runtime.SYNTHETICS_NODEJS_PUPPETEER_3_0
)
Note: For
code.fromAsset()andcode.fromBucket(), the canary resource requires the following folder structure:canary/ ├── nodejs/ ├── node_modules/ ├── <filename>.jsSee Synthetics docs.
Alarms
You can configure a CloudWatch Alarm on a canary metric. Metrics are emitted by CloudWatch automatically and can be accessed by the following APIs:
canary.metricSuccessPercent()- percentage of successful canary runs over a given timecanary.metricDuration()- how much time each canary run takes, in seconds.canary.metricFailed()- number of failed canary runs over a given time
Create an alarm that tracks the canary metric:
# Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
cloudwatch.Alarm(self, "CanaryAlarm",
metric=canary.metric_success_percent(),
evaluation_periods=2,
threshold=90,
comparison_operator=cloudwatch.ComparisonOperator.LESS_THAN_THRESHOLD
)
Future Work
- Add blueprints to the Test class #9613.
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-synthetics-1.94.0.tar.gz.
File metadata
- Download URL: aws-cdk.aws-synthetics-1.94.0.tar.gz
- Upload date:
- Size: 123.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/39.0.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.6.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
64b22841d99b5f1ad00b82831c1b0afd35d4eb24e3b68de0c25bcb7523f6a977
|
|
| MD5 |
f7fd804342b9e4057a80f7a53b156655
|
|
| BLAKE2b-256 |
9da309f609d684b4be4247f2320a073f184fffe09c1dcb10fd2f37d4625c55da
|
File details
Details for the file aws_cdk.aws_synthetics-1.94.0-py3-none-any.whl.
File metadata
- Download URL: aws_cdk.aws_synthetics-1.94.0-py3-none-any.whl
- Upload date:
- Size: 125.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/39.0.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.6.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a3c85d2cd94cfb331c26e4c68bcc03b65d79ab2d66904f19ec85dd7d1eec15c6
|
|
| MD5 |
880d8242b8f42b453498b9e0e3143cf1
|
|
| BLAKE2b-256 |
429b30bfa484210c4ce9441cd8763ac60b6293bf9a288defab5d646cabe6f2bd
|