사용자가 AWS Glue 데이터 카탈로그에서 여러 함수 정의의 세부 정보를 얻는 방법을 살펴보겠습니다.
예시
문제 설명: boto3 사용 Python의 라이브러리를 사용하여 AWS Glue Data Catalog에서 데이터베이스에 있는 여러 함수 정의의 세부 정보를 가져옵니다.
이 문제를 해결하기 위한 접근 방식/알고리즘
-
1단계: boto3 가져오기 및 보토코어 예외를 처리하는 예외.
-
2단계: database_name 및 regular_pattern은 선택적 매개변수입니다. 이에 대한 세부 정보가 제공되지 않으면 함수는 AWS 사용자 계정에 있는 모든 함수의 정의를 가져옵니다. database_name인 경우 제공되지만 regular_pattern 제공되지 않으면 지정된 데이터베이스의 모든 기능을 가져옵니다. 두 매개변수가 모두 제공되면 regular_pattern에 따라 일치하는 함수의 정의를 가져옵니다. . regular_pattern만 있는 경우 제공되면 regular_pattern과 일치하는 모든 기능을 가져옵니다. AWS 사용자 계정에 있음
-
3단계: boto3 lib를 사용하여 AWS 세션 생성 . region_name 기본 프로필에 언급되어 있습니다. 언급되지 않은 경우 region_name을 명시적으로 전달합니다. 세션을 만드는 동안.
-
4단계: 글루용 AWS 클라이언트 생성 .
-
5단계: get_multiple_function_definition 호출 database_name 전달 DatabaseName 및 regular_pattern으로 패턴 매개변수로.
-
6단계: 제공된 매개변수에 따라 여러 함수의 정의를 반환합니다.
-
7단계: 기능을 확인하는 동안 문제가 발생한 경우 일반 예외를 처리합니다.
예시 코드
다음 코드는 여러 함수의 정의를 가져옵니다 -
import boto3
from botocore.exceptions import ClientError
def get_multiple_function_definition(database_name =None, regular_pattern = None):
session = boto3.session.Session()
glue_client = session.client('glue')
try:
response = glue_client.get_user_defined_functions(DatabaseName=database_name,Pattern= regular_pattern)
return response
except ClientError as e:
raise Exception("boto3 client error in get_multiple_function_definition: " + e.__str__())
except Exception as e:
raise Exception("Unexpected error in get_multiple_function_definition: " + e.__str__())
a = get_multiple_function_definition('employee')
print(a) 출력
{
'UserDefinedFunctions':[{
'FunctionName': 'insert_employee_record',
'DatabaseName': 'employee',
'ClassName': 'InsertEmployee',
'OwnerName': 'string',
'OwnerType': 'USER'|'ROLE'|'GROUP',
'CreateTime': datetime(2021,03,15),
'ResourceUris':[
{
'ResourceType': 'JAR'|'FILE'|'ARCHIVE',
'Uri': 'string'
},
]
}]
}