Lambda 함수에 대해 컨테이너화된 이미지를 사용하고 있고 디버그를 모니터링하려면 Dockerfile에 New Relic을 추가해야 합니다. 예를 들어, 귀하가 예산 책정 애플리케이션 개발자이고 고객이 See my balance [내 잔액 보기 를] 클릭할 때마다 Lambda 함수를 사용하여 계정 잔액을 계산한다고 가정해 보겠습니다. 잠재적인 지연시간에 대해 자세히 알아보고 싶습니다. 이 경우 함수에 New Relic을 추가해야 하므로 고객이 See my balance [내 잔액 보기를] 클릭할 때마다 함수가 실행되고 New Relic도 실행됩니다.
다음은 함수를 모니터링할 수 있도록 Dockerfile에 New Relic을 추가하는 프로세스를 보여주는 다이어그램입니다.
Lambda 함수에 컨테이너화된 이미지를 사용하는 경우 이미지에 뉴렐릭을 추가할 수 있습니다.
다음은 사전 구축된 레이어를 코드에 추가하는 방법에 대한 가이드입니다.
Dockerfile에 뉴렐릭 추가
뉴렐릭은 레이어의 다양한 런타임(Java, Node.js, Python 및 확장 전용입니다.
특정 Lambda 함수의 런타임 및 지역과 호환되는 계층을 선택합니다.
다단계 Dockerfile에서 New Relic의 사전 빌드된 이미지를 중간 빌드 단계로 사용하세요. 그런 다음 사전 빌드된 이미지의 New Relic 에이전트 및 확장을 최종 빌드 단계에 복사하세요.
예시
다음은 New Relic의 사전 빌드된 레이어와 병합된 원본 Dockerfile의 예입니다. 이 예제에서는 Node.js 런타임을 사용합니다.
# Define the New Relic pre-built imageFROM public.ecr.aws/newrelic-lambda-layers-for-docker/newrelic-lambda-layers-nodejs:20 AS layer# Define the base image:FROM public.ecr.aws/lambda/nodejs:20# Copy New Relic Layer codeCOPY /opt/ /opt/# Rest of your Dockerfile...런타임 기반 Dockerfile 예제
FROM public.ecr.aws/newrelic-lambda-layers-for-docker/newrelic-lambda-layers-java:17-arm64 AS layer# Layer codeCOPY /opt/ /opt/FROM public.ecr.aws/newrelic-lambda-layers-for-docker/newrelic-lambda-layers-python:38-arm64 AS layer# Layer codeCOPY /opt/ /opt/FROM public.ecr.aws/newrelic-lambda-layers-for-docker/newrelic-lambda-layers-nodejs:20-arm64 AS layer# Layer codeCOPY /opt/ /opt/FROM public.ecr.aws/newrelic-lambda-layers-for-docker/newrelic-lambda-layers-ruby:32-arm64 AS layer# Layer codeCOPY /opt/ /opt/FROM public.ecr.aws/newrelic-lambda-layers-for-docker/newrelic-lambda-layers-dotnet:arm64 AS layer# Layer codeCOPY /opt/ /opt/FROM public.ecr.aws/newrelic-lambda-layers-for-docker/newrelic-lambda-layers-lambdaextension:x86 as layer# Layer codeCOPY /opt/ /opt/
이미지 만들기
- New Relic의 사전 빌드된 이미지에 대한 참조를 Dockerfile에 추가한 후 수정된 Dockerfile에서 새 이미지를 빌드해야 합니다. 이 새 이미지에는 원본 코드와 New Relic의 사전 빌드된 이미지가 포함됩니다. 이렇게 하려면 AWS 가이드 컨테이너 이미지를 사용하여 Lambda 함수 생성 에 나열된 단계를 따르는 것이 좋습니다.
- 배포를 위해 새 이미지를 AWS Elastic 컨테이너 레지스트리 에 푸시합니다.
새로운 Lambda 함수 생성
AWS ECR에 푸시한 이미지를 사용하여 새 Lambda 함수를 생성합니다. 이 함수 생성에 대한 자세한 내용을 보려면 AWS 가이드: Lambda 함수 생성 을 참조하는 것이 좋습니다.
Lambda 함수 구성
원본 함수와 동일한 설정으로 Lambda 함수를 구성하되, New Relic Lambda 모니터링에 필요한 환경 변수를 추가했는지 확인하세요. 자세한 내용은 환경 변수를 참조하세요.
함수의
cmd
재정의에서 새로 연결된 레이어를 가리키도록 함수 핸들러를 업데이트합니다. 다음 두 문서의 지침을 사용하여 그렇게 할 수 있습니다.