이 기사에서는 사용자가 AWS Glue 리소스에 태그를 추가하는 방법을 살펴보겠습니다.
예시
"glue-db:테스트 태그 추가 " AWS 글루 데이터베이스에 있습니다.
문제 설명: Python에서 boto3 라이브러리를 사용하여 AWS Glue 리소스에 태그를 추가합니다.
이 문제를 해결하기 위한 접근 방식/알고리즘
-
1단계: boto3 가져오기 및 보토코어 예외를 처리하는 예외.
-
2단계: resource_arn 및 tags_dict 이 함수의 필수 매개변수입니다.
resource_arn 형식 다음과 같아야 합니다 -
카탈로그 | arn:aws:glue:region:account-id:catalog |
데이터베이스 | arn:aws:glue:region:account-id:database/데이터베이스 이름 |
표 | arn:aws:glue:region:account-id:table/데이터베이스 이름/테이블 이름 |
연결 | arn:aws:glue:region:account-id:연결/연결 이름 |
크롤러 | arn:aws:glue:region:account-id:crawler/crawler-name |
작업 | arn:aws:glue:region:account-id:job/job-name |
트리거 | arn:aws:glue:region:account-id:trigger/trigger-name |
개발 엔드포인트 | arn:aws:glue:region:account-id:devEndpoint/development-endpoint-name |
기계 학습 혁신 | arn:aws:glue:region:account-id:mlTransform/transform-id |
tags_dict {"key":"value",..}
와 같아야 합니다.-
3단계: boto3 lib를 사용하여 AWS 세션 생성 . region_name을(를) 확인하십시오. 기본 프로필에 언급되어 있습니다. 언급되지 않은 경우 region_name을 명시적으로 전달합니다. 세션을 만드는 동안.
-
4단계: 글루용 AWS 클라이언트 생성 .
-
5단계: 이제 tag_resource를 사용하세요. 함수 및 매개변수 전달 resource_arn ResourceArn 및 tags_dict로 TagsToAdd로.
-
6단계: 응답 메타데이터를 반환하고 리소스에 태그를 추가합니다.
-
7단계: 태그를 추가하는 동안 문제가 발생한 경우 일반 예외를 처리합니다.
예시 코드
다음 코드를 사용하여 태그를 추가하십시오 -
import boto3 from botocore.exceptions import ClientError def add_tags_in_resource(resource_arn, tags_dict) session = boto3.session.Session() glue_client = session.client('glue') try: response = glue_client.tag_resource(ResourceArn= resource_arn,TagsToAdd=tags_dict) return response except ClientError as e: raise Exception("boto3 client error in add_tags_in_resource: " + e.__str__()) except Exception as e: raise Exception("Unexpected error in add_tags_in_resource: " + e.__str__()) tags_dict = {"glue-db":"test"} print(add_tags_in_resource("arn:aws:glue:us-east-1:1122225*****88:database/test- db",tags_dict))
출력
{'ResponseMetadata': {'RequestId': 'c9f418b0-***************-fb96', 'HTTPStatusCode': 200, 'HTTPHeaders': {'date': 'Fri, 02 Apr 2021 08:04:54 GMT', 'content-type': 'application/x-amz-json-1.1', 'content-length': '27', 'connection': 'keep-alive', 'x-amzn-requestid': 'c9f418b0-******************-fb96'}, 'RetryAttempts': 0}}