기계 번역으로 제공되는 번역입니다. 제공된 번역과 원본 영어의 내용이 상충하는 경우에는 영어 버전이 우선합니다.
Lambda Python으로 Lambda 함수 구성 업데이트 CodeBuild
다음 파이썬 샘플은 Boto3와
필수 조건
계정에서 Lambda 함수를 생성하거나 검색하십시오.
이 샘플은 계정에 Lambda 함수를 이미 생성했으며 Lambda 함수의 환경 변수를 CodeBuild 업데이트하는 데 사용할 것으로 가정합니다. Lambda 함수를 설정하는 방법에 대한 자세한 내용은 샘플 또는 CodeBuild Lambda 자바와 함께 사용하여 AWS SAM Lambda 함수를 배포하십시오. CodeBuild 을 참조하십시오. AWS Lambda
소스 리포지토리를 설정합니다.
Boto3 python 스크립트를 저장할 소스 리포지토리를 만드세요.
소스 리포지토리를 설정하려면
-
라는 새 파일에 다음 python 스크립트를
update_lambda_environment_variables.py
복사합니다.import boto3 from os import environ def update_lambda_env_variable(lambda_client): lambda_function_name = environ['LAMBDA_FUNC_NAME'] lambda_env_variable = environ['LAMBDA_ENV_VARIABLE'] lambda_env_variable_value = environ['LAMBDA_ENV_VARIABLE_VALUE'] print("Updating lambda function " + lambda_function_name + " environment variable " + lambda_env_variable + " to " + lambda_env_variable_value) lambda_client.update_function_configuration( FunctionName=lambda_function_name, Environment={ 'Variables': { lambda_env_variable: lambda_env_variable_value } }, ) if __name__ == "__main__": region = environ['AWS_REGION'] client = boto3.client('lambda', region) update_lambda_env_variable(client)
-
지원되는 소스 리포지토리에 python 파일을 업로드합니다. 지원되는 소스 유형 목록은 을 참조하십시오 ProjectSource.
CodeBuild Lambda Python 프로젝트 생성
CodeBuild Lambda Python 프로젝트를 생성합니다.
CodeBuild Lambda 자바 프로젝트를 생성하려면
-
https://console.aws.amazon.com/codesuite/codebuild/home
에서 AWS CodeBuild 콘솔을 엽니다. -
CodeBuild 정보 페이지가 표시되면 빌드 프로젝트 생성을 선택합니다. 그렇지 않을 경우, 탐색 창에서 빌드를 확장한 후 빌드 프로젝트를 선택하고 빌드 프로젝트 생성을 선택합니다.
프로젝트 이름에 이 빌드 프로젝트의 이름을 입력합니다. 각 AWS 계정에서 빌드 프로젝트 이름은 고유해야 합니다. 또한 선택에 따라 빌드 프로젝트에 대한 설명을 포함하여 다른 사용자가 이 프로젝트의 용도를 이해하도록 도울 수 있습니다.
-
소스에서 AWS SAM 프로젝트가 위치한 소스 저장소를 선택합니다.
-
환경에서 다음과 같이 합니다.
-
컴퓨팅에서 Lambda를 선택합니다.
-
런타임에서 Python을 선택합니다.
-
이미지의 경우 AWS/codebuild/amazonlinux-x86_64-람다-스탠다드:python3.12를 선택합니다.
-
서비스 역할의 경우 새 서비스 역할을 선택된 상태로 둡니다. 역할 이름을 기록해 둡니다. 이 샘플의 뒷부분에서 프로젝트의 IAM 권한을 업데이트할 때 필요합니다.
-
-
빌드 프로젝트 생성을 선택합니다.
-
https://console.aws.amazon.com/iam/
에서 IAM 콘솔을 엽니다. -
탐색 창에서 역할을 선택하고 프로젝트와 관련된 서비스 역할을 선택합니다. 에서 빌드 프로젝트를 선택하고 편집, 환경, 서비스 역할을 차례로 CodeBuild 선택하여 프로젝트 역할을 찾을 수 있습니다.
-
신뢰 관계(Trust relationships) 탭을 선택한 후 신뢰 정책 편집(Edit trust policy)을 선택합니다.
-
다음 인라인 정책을 IAM 역할에 추가합니다. 이는 나중에 AWS SAM 인프라를 배포하는 데 사용됩니다. 자세한 내용은 IAM 사용 설명서의 IAM 자격 증명 권한 추가 및 제거를 참조하세요.
{ "Version": "2012-10-17", "Statement": [ { "Sid": "UpdateLambdaPermissions", "Effect": "Allow", "Action": [ "lambda:UpdateFunctionConfiguration" ], "Resource": [ "*" ] } ] }
프로젝트 빌드 사양을 설정합니다.
Lambda 함수를 업데이트하기 위해 스크립트는 buildspec에서 환경 변수를 읽어 Lambda 함수 이름, 환경 변수 이름 및 환경 변수 값을 찾습니다.
프로젝트를 설정하려면: buildspec을 빌드하십시오.
-
CodeBuild 콘솔에서 빌드 프로젝트를 선택한 다음 편집 및 Buildspec을 선택합니다.
-
Buildspec에서 빌드 명령 삽입을 선택한 다음 편집기로 전환을 선택합니다.
-
미리 입력된 빌드 명령을 삭제하고 다음 빌드 사양에 붙여넣습니다.
version: 0.2 env: variables: LAMBDA_FUNC_NAME: "
<lambda-function-name>
" LAMBDA_ENV_VARIABLE: "FEATURE_ENABLED" LAMBDA_ENV_VARIABLE_VALUE: "true" phases: install: commands: - pip3 install boto3 build: commands: - python3 update_lambda_environment_variables.py -
Update buildspec(buildspec 업데이트)을 선택합니다.
Lambda 구성 업데이트
CodeBuild Lambda Python을 사용하여 Lambda 함수의 구성을 자동으로 업데이트하십시오.
Lambda 함수의 구성을 업데이트하려면
-
빌드 시작를 선택합니다.
-
빌드가 완료되면 Lambda 함수로 이동합니다.
-
구성을 선택한 다음 환경 변수를 선택합니다.
FEATURE_ENABLED
키와 값이 있는 새 환경 변수가 표시되어야true
합니다.
인프라를 정리하세요.
이 자습서에서 사용한 리소스에 대한 추가 요금이 부과되지 않도록 하려면 CodeBuild 프로젝트용으로 만든 리소스를 삭제하세요.
인프라를 정리하려면
-
CloudWatch 콘솔로 이동하여 CodeBuild 프로젝트와 관련된 CloudWatch 로그 그룹을 삭제합니다.
-
CodeBuild 콘솔로 이동한 다음 빌드 CodeBuild 프로젝트 삭제를 선택하여 프로젝트를 삭제합니다.
-
이 샘플의 목적으로 Lambda 함수를 생성한 경우, 작업 및 삭제 함수를 선택하여 Lambda 함수를 정리하십시오.
확장 프로그램
AWS CodeBuildLambda Python을 사용하여 이 샘플을 확장하여 다른 AWS 리소스를 관리하려는 경우:
-
Boto3를 사용하여 Python 스크립트를 업데이트하여 새 리소스를 수정합니다.
-
새 리소스에 대한 권한을 갖도록 CodeBuild 프로젝트와 관련된 IAM 역할을 업데이트하세요.
-
새 리소스와 관련된 모든 새 환경 변수를 buildspec에 추가합니다.