This example demonstrates how to use the AWS Observability Accelerator Terraform modules with Infrastructure monitoring enabled. The current example deploys the AWS Distro for OpenTelemetry Operator for Amazon EKS with its requirements and make use of an existing Amazon Managed Grafana workspace. It creates a new Amazon Managed Service for Prometheus workspace unless provided with an existing one to reuse.
It uses the EKS monitoring
module
to provide an existing EKS cluster with an OpenTelemetry collector,
curated Grafana dashboards, Prometheus alerting and recording rules with multiple
configuration options on the cluster infrastructure.
Ensure that you have the following tools installed locally:
This example uses a local terraform state. If you need states to be saved remotely, on Amazon S3 for example, visit the terraform remote states documentation
- Clone the repo using the command below
git clone https://github.com/aws-observability/terraform-aws-observability-accelerator.git
- Initialize terraform
cd examples/existing-cluster-with-base-and-infra
terraform init
- Amazon EKS Cluster
To run this example, you need to provide your EKS cluster name. If you don't have a cluster ready, visit this example first to create a new one.
Add your cluster name for eks_cluster_id="..."
to a new terraform.tfvars
file
or use an environment variable export TF_VAR_eks_cluster_id=xxx
.
- Amazon Managed Grafana workspace
To run this example you need an Amazon Managed Grafana workspace. If you have
an existing workspace, create an environment variable
export TF_VAR_managed_grafana_workspace_id=g-xxx
.
To create a new one, visit this example.
In the URL
https://g-xyz.grafana-workspace.eu-central-1.amazonaws.com
, the workspace ID would beg-xyz
Amazon Managed Service for Grafana provides a control plane API for generating Grafana API keys. We will provide to Terraform
a short lived API key to run the apply
or destroy
command.
Ensure you have necessary IAM permissions (CreateWorkspaceApiKey, DeleteWorkspaceApiKey
)
export TF_VAR_grafana_api_key=`aws grafana create-workspace-api-key --key-name "observability-accelerator-$(date +%s)" --key-role ADMIN --seconds-to-live 1200 --workspace-id $TF_VAR_managed_grafana_workspace_id --query key --output text`
terraform apply -var-file=terraform.tfvars
or if you had only setup environment variables, run
terraform apply
For the purpose of the example, we have provided default values for some of the variables.
- AWS Region
Specify the AWS Region where the resources will be deployed. Edit the terraform.tfvars
file and modify aws_region="..."
. You can also use environement variables export TF_VAR_aws_region=xxx
.
- Amazon Managed Service for Prometheus workspace
If you have an existing workspace, add managed_prometheus_workspace_id=ws-xxx
or use an environment variable export TF_VAR_managed_prometheus_workspace_id=ws-xxx
.
- Prometheus datasource on Grafana
Make sure to open the link in the output. After a successful deployment, this will open
the Prometheus datasource configuration on Grafana.
Click Save & test
and you should see a notification confirming that the Amazon Managed Service for Prometheus workspace is ready to be used on Grafana.
terraform output grafana_prometheus_datasource_test
- Grafana dashboards
Go to the Dashboards panel of your Grafana workspace. You should see a list of dashboards under the Observability Accelerator Dashboards
Open a specific dashboard and you should be able to view its visualization
- Amazon Managed Service for Prometheus rules and alerts
Open the Amazon Managed Service for Prometheus console and view the details of your workspace. Under the Rules management
tab, you should find new rules deployed.
To setup your alert receiver, with Amazon SNS, follow this documentation
If you leave this stack running, you will incur charges. To remove all resources created by Terraform, refresh your Grafana API key and run:
terraform destroy -var-file=terraform.tfvars
Name | Version |
---|---|
terraform | >= 1.1.0 |
aws | >= 4.0.0 |
grafana | >= 1.25.0 |
helm | >= 2.4.1 |
kubectl | >= 1.14 |
kubernetes | >= 2.10 |
Name | Version |
---|---|
aws | >= 4.0.0 |
Name | Source | Version |
---|---|---|
aws_observability_accelerator | ../../ | n/a |
eks_monitoring | ../../modules/eks-monitoring | n/a |
Name | Type |
---|---|
aws_eks_cluster.this | data source |
aws_eks_cluster_auth.this | data source |
Name | Description | Type | Default | Required |
---|---|---|---|---|
aws_region | AWS Region | string |
n/a | yes |
eks_cluster_id | Name of the EKS cluster | string |
"eks-cluster-with-vpc" |
no |
enable_dashboards | Enables or disables curated dashboards | bool |
true |
no |
grafana_api_key | API key for authorizing the Grafana provider to make changes to Amazon Managed Grafana | string |
n/a | yes |
managed_grafana_workspace_id | Amazon Managed Grafana Workspace ID | string |
n/a | yes |
managed_prometheus_workspace_id | Amazon Managed Service for Prometheus Workspace ID | string |
"" |
no |
Name | Description |
---|---|
aws_region | AWS Region |
eks_cluster_id | EKS Cluster Id |
eks_cluster_version | EKS Cluster version |
grafana_dashboard_urls | URLs for dashboards created |
grafana_prometheus_datasource_test | Grafana save & test URL for Amazon Managed Prometheus workspace |
managed_grafana_workspace_id | Amazon Managed Grafana workspace ID |
managed_prometheus_workspace_endpoint | Amazon Managed Prometheus workspace endpoint |
managed_prometheus_workspace_id | Amazon Managed Prometheus workspace ID |