# CloudWatch code examples for the SDK for C++ ## Overview Shows how to use the AWS SDK for C++ to work with Amazon CloudWatch. _CloudWatch provides a reliable, scalable, and flexible monitoring solution that you can start using within minutes._ ## ⚠ Important * Running this code might result in charges to your AWS account. For more details, see [AWS Pricing](https://aws.amazon.com/pricing/) and [Free Tier](https://aws.amazon.com/free/). * Running the tests might result in charges to your AWS account. * We recommend that you grant your code least privilege. At most, grant only the minimum permissions required to perform the task. For more information, see [Grant least privilege](https://docs.aws.amazon.com/IAM/latest/UserGuide/best-practices.html#grant-least-privilege). * This code is not tested in every AWS Region. For more information, see [AWS Regional Services](https://aws.amazon.com/about-aws/global-infrastructure/regional-product-services). ## Code examples ### Prerequisites Before using the code examples, first complete the installation and setup steps for [Getting started](https://docs.aws.amazon.com/sdk-for-cpp/v1/developer-guide/getting-started.html) in the AWS SDK for C++ Developer Guide. This section covers how to get and build the SDK, and how to build your own code by using the SDK with a sample Hello World-style application. Next, for information on code example structures and how to build and run the examples, see [Getting started with the AWS SDK for C++ code examples](https://docs.aws.amazon.com/sdk-for-cpp/v1/developer-guide/getting-started-code-examples.html). To run these code examples, your AWS user must have permissions to perform these actions with Amazon CloudWatch. The AWS managed policy named "CloudWatchFullAccess" may be used to bulk-grant the necessary permissions. For more information on attaching policies to IAM user groups, ### Single actions Code excerpts that show you how to call individual service functions. - [DeleteAlarms](delete_alarm.cpp#L15) - [DescribeAlarmsForMetric](describe_alarms.cpp#L13) - [DisableAlarmActions](disable_alarm_actions.cpp#L18) - [EnableAlarmActions](enable_alarm_actions.cpp#L20) - [ListMetrics](list_metrics.cpp#L18) - [PutMetricAlarm](put_metric_alarm.cpp#L18) - [PutMetricData](put_metric_data.cpp#L14) ## Run the examples ### Instructions An executable is built for each source file in this folder. These executables are located in the build folder and have "run_" prepended to the source file name, minus the suffix. See the "main" function in the source file for further instructions. For example, to run the action in the source file "my_action.cpp", execute the following command from within the build folder. The command will display any required arguments. ``` ./run_my_action ``` If the source file is in a different folder, instructions can be found in the README in that folder. ### Tests ⚠ Running tests might result in charges to your AWS account. ```sh cd cmake -DBUILD_TESTS=ON make ctest ``` ## Additional resources - [CloudWatch User Guide](https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/WhatIsCloudWatch.html) - [CloudWatch API Reference](https://docs.aws.amazon.com/AmazonCloudWatch/latest/APIReference/Welcome.html) - [SDK for C++ CloudWatch reference](https://sdk.amazonaws.com/cpp/api/LATEST/aws-cpp-sdk-monitoring/html/annotated.html) --- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. SPDX-License-Identifier: Apache-2.0