Boto3を使用して、AWSGlueに存在するジョブのジョブ実行をページ分割する方法
この記事では、AWSGlueに存在するジョブのすべてのジョブ実行をページ分割する方法を説明します。
例
問題の説明: boto3を使用する アカウントで作成されたAWSGlueDataCatalogからのジョブのジョブ実行をページ分割するPythonのライブラリ
この問題を解決するためのアプローチ/アルゴリズム
-
ステップ1: boto3をインポートします およびbotocore 例外を処理するための例外。
-
ステップ2: max_items 、 page_size およびstarting_token job_name は、この関数のオプションのパラメータです。 が必要です。
-
max_items 返されるレコードの総数を示します。利用可能なレコードの数>max_items 次にNextToken ページネーションを再開するための応答で提供されます。
-
page_size 各ページのサイズを示します。
-
starting_token ページ付けに役立ち、 NextTokenを使用します 以前の回答から。
-
-
ステップ3: boto3 libを使用してAWSセッションを作成します 。 region_nameを確認してください デフォルトのプロファイルに記載されています。言及されていない場合は、 region_nameを明示的に渡します セッションの作成中。
-
ステップ4: 接着剤用のAWSクライアントを作成します。
-
ステップ5: ページネーターを作成する get_job_runsを使用するすべてのクローラーの詳細を含むオブジェクト
-
ステップ6: paginate関数を呼び出して、 max_itemsを渡します 、 page_size およびstarting_token PaginationConfigとして パラメータ。
-
ステップ7: max_sizeに基づいてレコード数を返します およびpage_size 。
-
ステップ8: ページ付け中に問題が発生した場合は、一般的な例外を処理します。
サンプルコード
次のコードを使用して、ユーザーアカウントで作成されたジョブのすべてのジョブ実行をページ分割します-
import boto3 from botocore.exceptions import ClientError def paginate_through_jobruns(job_name,max_items=None:int,page_size=None:int, starting_token=None:string): session = boto3.session.Session() glue_client = session.client('glue') try: paginator = glue_client.get_paginator('get_job_runs') response = paginator.paginate(JobName=job_name, PaginationConfig={ 'MaxItems':max_items, 'PageSize':page_size, 'StartingToken':starting_token} ) return response except ClientError as e: raise Exception("boto3 client error in paginate_through_jobruns: " + e.__str__()) except Exception as e: raise Exception("Unexpected error in paginate_through_jobruns: " + e.__str__()) a = paginate_through_crawlers("glue_test_job",1,5) print(*a)
出力
{'JobRuns': [ {'Id': 'jr_435b66cfe451adf5fa7c7f914be3c87d199616f52bd13bdd91bb1269f02db705', 'Attempt': 0, 'JobName': ' glue_test_job, 'StartedOn': datetime.datetime(2021, 1, 25, 22, 19, 56, 52000, tzinfo=tzlocal()), 'LastModifiedOn': datetime.datetime(2021, 1, 25, 22, 21, 50, 603000, tzinfo=tzlocal()), 'CompletedOn': datetime.datetime(2021, 1, 25, 22, 21, 50, 603000, tzinfo=tzlocal()), 'JobRunState': 'SUCCEEDED', 'Arguments': {'--additional-python-modules': 'pandas==1.1.5', '--enable-glue-datacatalog': 'true', '--extra-files': 's3://glue/job/test, '--job-bookmark-option': 'job-bookmark-disable', 'step': '0'}, 'PredecessorRuns': [], 'AllocatedCapacity': 2, 'ExecutionTime': 107, 'Timeout': 2880, 'MaxCapacity': 2.0, 'WorkerType': 'G.1X', 'NumberOfWorkers': 2, 'LogGroupName': '/aws-glue/jobs', 'GlueVersion': '2.0'}], 'NextToken': 'eyJleHBpcmF0aW9uIjp7InNlY29uZHMiOjE2MTc0NTQ0NDgsIm5hbm9zIjo2OTUwMDAwMDB9LCJsYXN0RXZhbHVhdGVkS2V5Ijp7ImpvYklkIjp7InMiOiJqXzdlYzIzNTYwOWRkMGVmYjRhNTgyNDU2YWVlZmQ4NmFlMTgwYTAyNDQ3NWY2ODRkMzc4YWFiZDBmYTk1MGJmMDcifSwicnVuSWQiOnsicyI6ImpyXzJjNDFkMmJmMzY1NGZhZGFhYzkzMjU1ZTY0OTkxOTg2YTE0Yjk2MjIyMTRlNDc4ZGNkOWE0ZTY5N2M3MGZmY2YifSwic3RhcnRlZE9uIjp7Im4iOiIxNjExMjA3MjcwODIyIn19fQ==', 'ResponseMetadata': {'RequestId': '1874370e-***********-40d', 'HTTPStatusCode': 200, 'HTTPHeaders': {'date': 'Fri, 02 Apr 2021 12:54:08 GMT', 'content-type': 'application/x-amz-json-1.1', 'content-length': '6509', 'connection': 'keep-alive', 'x-amzn-requestid': '1874370e-**************40d'}, 'RetryAttempts': 0}}
-
Boto3を使用してAWSGlueから接着剤ジョブを削除するにはどうすればよいですか?
問題の説明 − Pythonでboto3ライブラリを使用して、アカウントで作成された接着剤ジョブを削除します。 例 −アカウントで作成された接着剤ジョブ「transfer_from_s3」を削除します。 この問題を解決するためのアプローチ/アルゴリズム ステップ1 −例外を処理するためにboto3およびbotocore例外をインポートします。 ステップ2 −AWSGlueカタログから削除する必要があるパラメータjob_nameを渡します。 ステップ3 −boto3ライブラリを使用してAWSセッションを作成します。 region_nameがデフォルトのプロファイルに記載されていることを確
-
Boto3を使用して実行中のGlueジョブのステータスを確認するにはどうすればよいですか?
問題の説明 − Pythonでboto3ライブラリを使用して、接着ジョブを実行し、成功したか失敗したかを示すステータスを取得します。たとえば、ジョブ run_s3_file_jobを実行します ステータスを取得します。 この問題を解決するためのアプローチ/アルゴリズム ステップ1 −例外を処理するためにboto3およびbotocore例外をインポートします。 ステップ2 − job_name は必須パラメータですが、引数 関数のオプションのパラメータです。実行するために引数を取るジョブはほとんどありません。その場合、引数はdictとして渡すことができます。 例: arguments