Computer >> Máy Tính >  >> Lập trình >> Python

Cách sử dụng Boto3 để nhận danh sách các lược đồ có trong tài khoản AWS

Trong bài viết này, chúng ta sẽ xem cách người dùng có thể lấy danh sách tất cả các lược đồ có trong tài khoản AWS.

Ví dụ

Nhận danh sách tất cả các lược đồ có sẵn trong Danh mục dữ liệu AWS Glue.

Tuyên bố sự cố: Sử dụng boto3 thư viện bằng Python để lấy danh sách tất cả các lược đồ.

Phương pháp tiếp cận / Thuật toán để giải quyết vấn đề này

  • Bước 1: Nhập boto3 botocore các ngoại lệ để xử lý các ngoại lệ.

  • Bước 2: Không có tham số nào trong hàm này.

  • Bước 3: Tạo phiên AWS bằng boto3 lib . Đảm bảo rằng tên_vùng được đề cập trong hồ sơ mặc định. Nếu nó không được đề cập, thì hãy chuyển region_name một cách rõ ràng trong khi tạo phiên.

  • Bước 4: Tạo ứng dụng AWS cho keo .

  • Bước 5: Bây giờ, hãy sử dụng list_schemas chức năng

  • Bước 6: Nó trả về danh sách tất cả các lược đồ có trong danh mục dữ liệu AWS Glue với các chi tiết giới hạn của lược đồ. Nó không bao gồm các lược đồ có trạng thái là Xóa. Nó chỉ có danh sách các lược đồ có sẵn. Nếu không có lược đồ nào, thì nó trả về một mệnh đề trống.

  • Bước 7: Xử lý ngoại lệ chung nếu có sự cố trong khi kiểm tra các lược đồ.

Mã mẫu

Đoạn mã sau tìm nạp danh sách tất cả các lược đồ -

import boto3
from botocore.exceptions import ClientError

def list_of_schemas()
   session = boto3.session.Session()
   glue_client = session.client('glue')
   try:
      schemas_name = glue_client.list_schemas()
      return schemas_name
   except ClientError as e:
      raise Exception("boto3 client error in list_of_schemas: " + e.__str__())
   except Exception as e:
      raise Exception("Unexpected error in list_of_schemas: " + e.__str__())
print(list_of_schemas())

Đầu ra

{
   'Schemas':[
   {
      'RegistryName': 'employee_details',
      'SchemaName': 'employee_table',
      'SchemaArn': 'string',
      'Description': 'Schema for employees record',
      'Status': 'AVAILABLE',
      'CreatedTime': 'string',
      'UpdatedTime': 'string'
   },
   {
      'RegistryName': 'security_details',
      'SchemaName': 'security_table',
      'SchemaArn': 'string',
      'Description': 'Schema for security record',
      'Status': 'AVAILABLE',
      'CreatedTime': 'string',
      'UpdatedTime': 'string'
   },
],
'Request': ……
}