Go 람다 함수가 여전히 런타임 go1.x를 사용하고 provided.al2 런타임으로 마이그레이션할 수 없다면, Datadog 포워더(Forwarder)를 사용해 계측해야 합니다. 또는 이 가이드의 지침을 따라 Datadog 람다 확장을 사용해 계측하세요.
람다(Lambda) 함수가 공용 인터넷에 액세스할 수 없는 VPC에 배포된 경우, datadoghq.com Datadog 사이트의 경우 AWS PrivateLink를 사용하여 데이터를 전송하거나, 다른 모든 사이트의 경우 프록시를 사용하여 데이터를 전송할 수 있습니다.

설치

Datadog 서버리스 플러그인Datadog 람다 확장을 통해 메트릭, 트레이스, 로그를 Datadog로 전송하도록 함수를 자동 설정합니다.

Datadog 서버리스 플러그인을 설치 및 설정하려면 다음 단계를 따르세요:

Datadog 서버리스 플러그인을 설치합니다.

serverless plugin install --name serverless-plugin-datadog

serverless.yml을 업데이트합니다.

custom:
  datadog:
    site: <DATADOG_SITE>
    apiKeySecretArn: <DATADOG_API_KEY_SECRET_ARN>

플레이스홀더를 채우려면:

  • <DATADOG_SITE>를 텔레메트리 전송 대상인 Datadog 사이트로 대체합니다.
  • <DATADOG_API_KEY_SECRET_ARN>Datadog API 키가 안전하게 저장된 AWS 시크릿의 ARN으로 대체합니다. 키는 플레인 텍스트 스트링으로 저장해야 합니다(JSON blob이 아님에 유의하세요). 또한, secretsmanager:GetSecretValue 권한이 있어야 합니다. 빠른 테스트를 위해 대신 apiKey를 사용하고 Datadog API 키를 플레인 텍스트로 설정할 수 있습니다.

더 자세한 정보와 추가 설정 방법은 플러그인 설명서에서 찾아볼 수 있습니다.

  1. Datadog 람다 확장 설치

    COPY --from=public.ecr.aws/datadog/lambda-extension:<TAG> /opt/. /opt/
    

    <TAG>을 특정 버전 번호(예: 68) 또는 latest 으로 바꿉니다. Alpine은 특정 버전 번호(예: 68-alpine) 또는 latest-alpine으로도 지원됩니다. 가능한 태그 의 전체 목록을 Amazon ECR 리포지토리에서 확인할 수 있습니다.

  2. 필요한 환경 변수를 설정합니다.

    • DD_SITE(오른쪽에서 올바른 사이트(SITE)가 선택되었는지 확인)로 설정합니다.
    • DD_API_KEY_SECRET_ARNDatadog API 키가 안전하게 저장된 AWS 시크릿의 ARN으로 대체합니다. 키는 플레인 텍스트 스트링으로 저장해야 합니다(JSON blob이 아님에 유의하세요). 또한, secretsmanager:GetSecretValue 권한이 필요합니다. 빠른 테스트를 위해 대신 DD_API_KEY를 사용하고 Datadog API 키를 플레인 텍스트로 설정할 수 있습니다.
    • 선택적으로 DD_UNIVERSAL_INSTRUMENTATION: true를 설정하여 람다 요청 및 응답 페이로드 캡처, 수신 람다 이벤트에서 APM 스팬 추론 등 고급 설정의 이점을 누릴 수 있습니다.

Datadog 람다 확장 설치

AWS 리전 및 아키텍처 기준 ARN 형식을 따라 Datadog 람다 확장의 람다 레이어를 람다 함수에 추가하세요.

# AWS 상업 리전에 구축된 x86 기반 람다의 경우 이 형식 사용
arn:aws:lambda:<AWS_REGION>:464622532012:layer:Datadog-Extension:68

# AWS 상업 리전에 구축된 arm64 기반 람다의 경우 이 형식 사용
arn:aws:lambda:<AWS_REGION>:464622532012:layer:Datadog-Extension-ARM:68

# AWS GovCloud 리전에 구축된 x86 기반 람다의 경우 이 형식 사용
arn:aws-us-gov:lambda:<AWS_REGION>:002406178527:layer:Datadog-Extension:68

# AWS GovCloud 리전에 구축된 arm64 기반 람다의 경우 이 형식 사용
arn:aws-us-gov:lambda:<AWS_REGION>:002406178527:layer:Datadog-Extension-ARM:68

<AWS_REGION>us-east-1와 같이 유효한 AWS 지역으로 대체합니다.

필수 환경 변수 설정

  • DD_SITE(오른쪽에서 올바른 사이트(SITE)가 선택되었는지 확인)로 설정합니다.
  • DD_API_KEY_SECRET_ARN을 [Datadog API 키2가 안전하게 저장되는 AWS 암호 ARN으로 설정하세요. 키는 일반 텍스트 문자열(JSON blob 안 됨)로 저장해야 합니다. secretsmanager:GetSecretValue 권한이 필요합니다. 빠른 테스트를 위해 대신 DD_API_KEY 키를 사용하고 일반 텍스트로 Datadog API 키를 설정할 수 있습니다.

Datadog 람다 라이브러리 설치하기

go get github.com/DataDog/datadog-lambda-go

람다 함수 코드 업데이트

package main

import (
    "context"
    "net/http"
    "time"

    ddlambda "github.com/DataDog/datadog-lambda-go"
    "github.com/aws/aws-lambda-go/events"
    "github.com/aws/aws-lambda-go/lambda"
    httptrace "gopkg.in/DataDog/dd-trace-go.v1/contrib/net/http"
    "gopkg.in/DataDog/dd-trace-go.v1/ddtrace/tracer"
)

func main() {
    // Wrap your lambda handler
    lambda.Start(ddlambda.WrapFunction(myHandler, nil))
}

func myHandler(ctx context.Context, _ events.APIGatewayProxyRequest) (string, error) {
    // Trace an HTTP request
    req, _ := http.NewRequestWithContext(ctx, "GET", "https://www.datadoghq.com", nil)
    client := http.Client{}
    client = *httptrace.WrapClient(&client)
    client.Do(req)

    // Submit a custom metric
    ddlambda.Metric(
        "coffee_house.order_value",      // Metric name
        12.45,                           // Metric value
        "product:latte", "order:online", // Associated tags
    )

    // Create a custom span
    s, _ := tracer.StartSpanFromContext(ctx, "child.span")
    time.Sleep(100 * time.Millisecond)
    s.Finish()
    return "ok", nil
}

}

다음 단계

  • 축하합니다! 이제 서버리스 홈페이지에서 메트릭, 로그 및 트레이스를 확인할 수 있습니다.
  • 위협 모니터링을 켜서 귀하의 서비스를 목표로 하는 공격자에 대한 알림을 받으세요.
  • 원격 분석 수집에 문제가 있는 경우 트러블슈팅 가이드를 참조하세요.
  • 고급 설정을 참조해 다음을 수행할 수 있습니다.
    • 태그를 사용해 텔레메트리 연결
    • Amazon API 게이트웨이, SQS 등을 위한 원격 측정값을 수집합니다.
    • 람다 요청과 응답 페이로드 캡처
    • 람다 함수의 오류를 소스 코드에 링크
    • 로그나 트레이스에서 민감 정보를 필터링 또는 스크러빙

참고 자료