Computer >> 컴퓨터 >  >> 프로그램 작성 >> Python

Boto3를 사용하여 AWS Glue 데이터 카탈로그에서 데이터베이스의 사용자 정의 함수에 대한 세부 정보를 얻는 방법

<시간/>

사용자가 AWS Glue 데이터 카탈로그에서 지정된 함수 정의의 세부 정보를 얻는 방법을 살펴보겠습니다.

예시

insert_employee_record라는 함수 정의의 세부정보를 가져옵니다. 데이터베이스 직원 .

문제 설명: boto3 사용 Python의 라이브러리를 사용하여 AWS Glue 데이터 카탈로그에서 지정된 함수 정의의 세부 정보를 가져옵니다.

이 문제를 해결하기 위한 접근 방식/알고리즘

  • 1단계: boto3 가져오기 및 보토코어 예외를 처리하는 예외.

  • 2단계: database_namefunction_name 필수 매개변수입니다. 주어진 function_name의 정의를 가져옵니다. 주어진 데이터베이스에서.

  • 3단계: boto3 lib를 사용하여 AWS 세션 생성 . region_name 기본 프로필에 언급되어 있습니다. 언급되지 않은 경우 region_name을 명시적으로 전달합니다. 세션을 만드는 동안.

  • 4단계: 글루용 AWS 클라이언트 생성 .

  • 5단계: get_user_defined_function 호출 database_name 전달 DatabaseName 및 function_name으로 FunctionName 매개변수로.

  • 6단계: 주어진 함수의 정의를 반환합니다. 주어진 함수를 찾지 못하면 오류가 발생합니다.

  • 7단계: 기능을 확인하는 동안 문제가 발생한 경우 일반 예외를 처리합니다.

예시 코드

다음 코드는 주어진 함수의 정의를 가져옵니다 -

import boto3
from botocore.exceptions import ClientError

def get_function_definition(database_name, function_name):
   session = boto3.session.Session()
   glue_client = session.client('glue')
   try:
      response = glue_client.get_user_defined_function(DatabaseName=database_name, FunctionName=function_name)
      return response
   except ClientError as e:
      raise Exception("boto3 client error in get_function_definition: " + e.__str__())
   except Exception as e:
      raise Exception("Unexpected error in get_function_definition: " + e.__str__())
a = get_function_definition('employee', 'insert_employee_record')
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'
         },
      ],
   }
}