如何使用 Boto3 从 AWS Glue 数据目录中获取数据库中用户定义函数的详细信息

awsboto3pythonserver side programmingprogramming

让我们看看用户如何从 AWS Glue 数据目录中获取指定函数定义的详细信息。

示例

获取数据库 employee 中名为 insert_employee_record 的函数定义的详细信息。

问题陈述:使用 Python 中的 boto3 库从 AWS Glue 数据目录中获取指定函数定义的详细信息。

解决此问题的方法/算法

  • 步骤 1:导入 boto3botocore 异常来处理异常。

  • 步骤 2: database_namefunction_name 是必需参数。它获取给定数据库中给定 function_name 的定义。

  • 步骤 3: 使用 boto3 lib 创建 AWS 会话。确保默认配置文件中提到了 region_name。如果没有提及,则在创建会话时明确传递 region_name

  • 步骤 4:glue 创建 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'
         },
      ],
   }
}

相关文章