-
Notifications
You must be signed in to change notification settings - Fork 242
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add a topic explaining Amazon ECS and AWS Fargate telemetry collection (
#1466) * First draft of an ECS collect topic * First draft of an ECS collect topic * Initiall restructing of the topic * more general cleanup and alignment * Update heading levels * Cleaning up the AWS steps * Update text and wording * Apply suggestions from code review * More content fixes and cleanup * fix up some links * Fix typos
- Loading branch information
1 parent
c01bfa8
commit 57623e7
Showing
1 changed file
with
102 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,102 @@ | ||
--- | ||
canonical: https://grafana.com/docs/alloy/latest/collect/ecs-opentelemetry-data/ | ||
description: Learn how to collect Amazon ECS or AWS Fargate OpenTelemetry data and forward it to any OpenTelemetry-compatible endpoint | ||
menuTitle: Collect ECS or Fargate OpenTelemetry data | ||
title: Collect Amazon Elastic Container Service or AWS Fargate OpenTelemetry data | ||
weight: 500 | ||
--- | ||
|
||
# Collect Amazon Elastic Container Service or AWS Fargate OpenTelemetry data | ||
|
||
You can configure {{< param "FULL_PRODUCT_NAME" >}} to collect OpenTelemetry-compatible data from Amazon Elastic Container Service (ECS) or AWS Fargate and forward it to any OpenTelemetry-compatible endpoint. | ||
|
||
There are three different ways you can use {{< param "PRODUCT_NAME" >}} to collect Amazon ECS or AWS Fargate telemetry data. | ||
|
||
1. [Use a custom OpenTelemetry configuration file from the SSM Parameter store](#use-a-custom-opentelemetry-configuration-file-from-the-ssm-parameter-store). | ||
1. [Create an ECS task definition](#create-an-ecs-task-definition). | ||
1. [Run {{< param "PRODUCT_NAME" >}} directly in your instance, or as a Kubernetes sidecar](#run-alloy-directly-in-your-instance-or-as-a-kubernetes-sidecar). | ||
|
||
## Before you begin | ||
|
||
* Ensure that you have basic familiarity with instrumenting applications with OpenTelemetry. | ||
* Have an available Amazon ECS or AWS Fargate deployment. | ||
* Identify where {{< param "PRODUCT_NAME" >}} writes received telemetry data. | ||
* Be familiar with the concept of [Components][] in {{< param "PRODUCT_NAME" >}}. | ||
|
||
## Use a custom OpenTelemetry configuration file from the SSM Parameter store | ||
|
||
You can upload a custom OpenTelemetry configuration file to the SSM Parameter store and use {{< param "PRODUCT_NAME" >}} as a telemetry data collector. | ||
|
||
You can configure the AWS Distro for OpenTelemetry Collector with the `AOT_CONFIG_CONTENT` environment variable. | ||
This environment variable contains a full collector configuration file and it overrides the configuration file used in the collector entry point command. | ||
In ECS, you can set the values of environment variables from AWS Systems Manager Parameters. | ||
|
||
### Update the task definition | ||
|
||
1.Select the task definition. | ||
|
||
1. Open the AWS Systems Manager console. | ||
1. Select Elastic Container Service. | ||
1. In the navigation pane, choose *Task definition*. | ||
1. Choose *Create new revision*. | ||
|
||
1. Add an environment variable. | ||
|
||
1. Select the AWS Distro for OpenTelemetry Collector container and navigate to the Environment variables section. | ||
1. Add an environment variable named `AOT_CONFIG_CONTENT`. | ||
1. Select `ValueFrom` to tell ECS to get the value from the SSM Parameter, and set the value to `otel-collector-config`. | ||
|
||
1. Finish updating the task definition and create your revision. | ||
|
||
### Create the SSM parameter | ||
|
||
1. Open the AWS Systems Manager console. | ||
1. In the navigation pane, choose *Parameter Store*. | ||
1. Choose *Create parameter*. | ||
1. Create a parameter with the following values: | ||
|
||
* `Name`: otel-collector-config | ||
* `Tier`: Standard | ||
* `Type`: String | ||
* `Data type`: Text | ||
* `Value`: Copy and paste your custom OpenTelemetry configuration file or [{{< param "PRODUCT_NAME" >}} configuration file][configure]. | ||
|
||
### Run your task | ||
|
||
When you run a task with this Task Definition, it uses your custom OpenTelemetry configuration file from the SSM Parameter store. | ||
|
||
Refer to [Running an application as an Amazon ECS task][run] for more information about running your application as a task. | ||
|
||
## Create an ECS Task definition | ||
|
||
To create an ECS Task Definition for AWS Fargate with an ADOT collector, complete the following steps. | ||
|
||
1. Download the [ECS Fargate task definition template][template] from GitHub. | ||
1. Edit the task definition template and add the following parameters. | ||
* `{{region}}`: The region the data is sent to. | ||
* `{{ecsTaskRoleArn}}`: The AWSOTTaskRole ARN. | ||
* `{{ecsExecutionRoleArn}}`: The AWSOTTaskExcutionRole ARN. | ||
* `command` - Assign a value to the command variable to select the path to the configuration file. | ||
The AWS Collector comes with two configurations. Select one of them based on your environment: | ||
* Use `--config=/etc/ecs/ecs-default-config.yaml` to consume StatsD metrics, OTLP metrics and traces, and X-Ray SDK traces. | ||
* Use `--config=/etc/ecs/container-insights/otel-task-metrics-config.yaml` to use StatsD, OTLP, Xray, and Container Resource utilization metrics. | ||
1. Follow the ECS Fargate setup instructions to [create a task definition][task] using the template. | ||
|
||
## Run {{% param "PRODUCT_NAME" %}} directly in your instance, or as a Kubernetes sidecar | ||
|
||
SSH or connect to the Amazon ECS or AWS Fargate-managed container. Refer to [9 steps to SSH into an AWS Fargate managed container][steps] for more information about using SSH with Amazon ECS or AWS Fargate. | ||
|
||
You can also use your own method to connect to the Amazon ECS or AWS Fargate-managed container as long as you can pass the parameters needed to install and configure {{< param "PRODUCT_NAME" >}}. | ||
|
||
### Install Grafana Alloy | ||
|
||
After connecting to your instance, follow the {{< param "PRODUCT_NAME" >}} [installation][install], [configuration][configure] and [deployment][deploy] instructions. | ||
|
||
[Components]: https://grafana.com/docs/alloy/<ALLOY_VERSION>/get-started/components | ||
[template]: https://github.com/aws-observability/aws-otel-collector/blob/master/examples/ecs/aws-cloudwatch/ecs-fargate-sidecar.json | ||
[configure]: https://grafana.com/docs/alloy/<ALLOY_VERSION>/configure/ | ||
[steps]: https://medium.com/ci-t/9-steps-to-ssh-into-an-aws-fargate-managed-container-46c1d5f834e2 | ||
[install]: https://grafana.com/docs/alloy/<ALLOY_VERSION>/set-up/install/linux/ | ||
[deploy]: https://grafana.com/docs/alloy/<ALLOY_VERSION>/set-up/deploy/ | ||
[task]: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_definitions.html | ||
[run]: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/standalone-task-create.html |