2015-10-26 21:21:38 +08:00
----
page_title: Cloudwatch
page_description: Cloudwatch grafana datasource documentation
page_keywords: Cloudwatch, grafana, documentation, datasource, docs
---
2015-10-26 22:41:08 +08:00
# CloudWatch
2015-10-26 21:21:38 +08:00
2015-10-26 22:41:08 +08:00
Grafana ships with built in support for CloudWatch. You just have to add it as a data source and you will
be ready to build dashboards for you CloudWatch metrics.
2015-10-26 21:21:38 +08:00
## Adding the data source
2015-10-26 22:41:08 +08:00

2015-10-26 21:21:38 +08:00
1. Open the side menu by clicking the the Grafana icon in the top header.
2. In the side menu under the `Dashboards` link you should find a link named `Data Sources` .
> NOTE: If this link is missing in the side menu it means that your current user does not have the `Admin` role for the current organization.
3. Click the `Add new` link in the top header.
2015-10-26 22:41:08 +08:00
4. Select `CloudWatch` from the dropdown.
2015-10-26 21:21:38 +08:00
Name | Description
------------ | -------------
Name | The data source name, important that this is the same as in Grafana v1.x if you plan to import old dashboards.
Default | Default data source means that it will be pre-selected for new panels.
2015-10-29 19:22:01 +08:00
Credentials profile name | Specify the name of the profile to use (if you use `~/aws/credentials` file), leave blank for default. This option was introduced in Grafana 2.5.1
Default Region | Used in query editor to set region (can be changed on per query basis)
2015-10-26 21:21:38 +08:00
2015-10-26 22:41:08 +08:00
## Authentication
### IAM Roles
2015-10-27 12:02:04 +08:00
Currently all access to CloudWatch is done server side by the Grafana backend using the official AWS SDK. If you grafana
2015-10-26 22:41:08 +08:00
server is running on AWS you can use IAM Roles and authentication will be handled automatically.
2016-03-03 12:33:52 +08:00
Checkout AWS docs on [IAM Roles ](http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/iam-roles-for-amazon-ec2.html )
2015-10-26 22:41:08 +08:00
### AWS credentials file
Create a file at `~/.aws/credentials` . That is the `HOME` path for user running grafana-server.
Example content:
[default]
aws_access_key_id = asdsadasdasdasd
aws_secret_access_key = dasdasdsadasdasdasdsa
region = us-west-2
2015-10-26 22:51:34 +08:00
## Metric Query Editor
2015-10-26 22:41:08 +08:00

You need to specify a namespace, metric, at least one stat, and at least one dimension.
2015-10-29 22:46:10 +08:00
## Templated queries
CloudWatch Datasource Plugin provides the following functions in `Variables values query` field in Templating Editor to query `region` , `namespaces` , `metric names` and `dimension keys/values` on the CloudWatch.
Name | Description
------- | --------
`regions()` | Returns a list of regions AWS provides their service.
`namespaces()` | Returns a list of namespaces CloudWatch support.
`metrics(namespace)` | Returns a list of metrics in the namespace.
`dimension_keys(namespace)` | Returns a list of dimension keys in the namespace.
2015-12-04 00:04:50 +08:00
`dimension_values(region, namespace, metric, dimension_key)` | Returns a list of dimension values matching the specified `region` , `namespace` , `metric` and `dimension_key` .
2016-03-11 17:14:29 +08:00
`ebs_volume_ids(region, instance_id)` | Returns a list of volume id matching the specified `region` , `instance_id` .
`ec2_instance_attribute(region, attribute_name, filters)` | Returns a list of attribute matching the specified `region` , `attribute_name` , `filters` .
2015-10-29 22:46:10 +08:00
For details about the metrics CloudWatch provides, please refer to the [CloudWatch documentation ](https://docs.aws.amazon.com/AmazonCloudWatch/latest/DeveloperGuide/CW_Support_For_AWS.html ).
2016-03-11 17:14:29 +08:00
The `ec2_instance_attribute` query take `filters` in JSON format.
You can specify [pre-defined filters of ec2:DescribeInstances ](http://docs.aws.amazon.com/AWSEC2/latest/APIReference/API_DescribeInstances.html ).
Specify like `{ filter_name1: [ filter_value1 ], filter_name2: [ filter_value2 ] }`
Example `ec2_instance_attribute()` query
ec2_instance_attribute(us-east-1, InstanceId, { "tag:Environment": [ "production" ] })
2015-10-29 22:46:10 +08:00

2015-10-26 22:41:08 +08:00
2015-10-26 22:51:34 +08:00
## Cost
2015-10-26 22:41:08 +08:00
It's worth to mention that Amazon will charge you for CloudWatch API usage. CloudWatch costs
$0.01 per 1,000 GetMetricStatistics or ListMetrics requests. For each query Grafana will
2015-10-27 12:02:04 +08:00
issue a GetMetricStatistics request and every time you pick a dimension in the query editor
2015-10-26 22:41:08 +08:00
Grafana will issue a ListMetrics request.
2015-10-26 21:21:38 +08:00