この記事は公開されてから1年以上経過しています。情報が古い可能性がありますので、ご注意ください。
boto3 で楽しむ AWS PythonLife 一人AdventCalendarです。
boto3のドキュメントを通して、サービス別にどういった事が出来るのかを理解したり、管理コンソールを通さずにTerminalだけで完結できるように検証していくことが目的になります。
1日目はboto3そのものについてまとめてみました。
boto3とは
AWS SDK for Pythonです。名前はアマゾンカワイルカ(英名:Boto)に由来しています。
It was named after the fresh water dolphin native to the Amazon river. I wanted something short, unusual, and with at least some kind of connection to Amazon. Boto seemed to fit the bill 8^)
インストール方法
PyPiからインストールします。awscliを併用してアカウント設定を簡略化します。
% pipenv install boto3 awscli
% pipenv shell
% aws configure --profile advent_calendar
AWS Access Key ID [None]: XXXXXXXXXXXXXXXXXXXXXXXX
AWS Secret Access Key [None]: XXXXXXXXXXXXXXXXXXXXXXXX
Default region name [None]: us-east-1
Default output format [None]: json
今回はadvent_calendarの名称で設定しました。 roleの指定が必要な場合は以下の手順で指定します。
% vim ~/.aws/config
[profile advent_calendar]
role_arn arn:aws:iam::XXXXXXXXXXXX:role/XXXXXXXXXXXXX
roleは以下のコマンドで確認できます。
% aws iam list-roles | jq '.Roles[].Arn'
関連するモジュール
pipenv graph
で分かる依存関係は以下の通りです。boto及びaws関連のみ表示するため、幾つか割愛しています。
% pipenv graph
aws-shell
- awscli
- botocore
- s3transfer
- botocore
- boto3
- botocore
- s3transfer
- botocore
botocore
boto3のコア実装です。
s3transfer
S3の転送をPythonコードにて実施するためのライブラリです。
aws-cli
AWSを操作するコマンドラインのインターフェイスライブラリです。
aws-shell
シェルのような補完機能がある、AWSサービスを操作するライブラリです。
使い方
aws configure
にて設定したプロファイルを利用した場合は以下の様になります。
import boto3
session = boto3.Session(profile_name='advent_calendar')
また、リソースを対象とするのか、サービスを対象とするのかによって呼び出し方が異なってきます。必要に応じて、
- リソースを使う場合は
get_available_resources()
- サービスを使う場合は
get_available_services()
にて確認しておきましょう。
import boto3
target_resource_name = "s3"
target_service_name = "s3"
session = boto3.Session(profile_name='advent_calendar')
if target_resource_name not in session.get_available_resources():
for resource in session.get_available_resources():
print("- {}".format(resource))
raise Exception("Not exist in resources : {}".format(target_resource_name))
if target_service_name not in session.get_available_services():
for service in session.get_available_services():
print("- {}".format(service))
raise Exception("Not exist in services : {}".format(target_service_name))
対象サービス
AWS上でboto3による利用アナウンスが存在している状態ながら実際に使えない場合は、boto3のアップデートが必要です。
対象リソース
対象サービスよりも対象が絞られています。
import boto3
session = boto3.Session(profile_name='advent_calendar')
for resource in session.get_available_resources():
print("- {}".format(resource))
- cloudformation
- cloudwatch
- dynamodb
- ec2
- glacier
- iam
- opsworks
- s3
- sns
- sqs
各サービス毎の使い方
サービス及びリソース別での使い方は公式ドキュメントに全て記載されているため、必要に応じて参照してください。
まとめ
awscliを使ってshellによる操作で完了させている場合はboto3に触ることが少ないかもしれません。
Pythonでのコーディングを行っていながらもAWSのサービス操作はawscli経由のみだった方には特に使ってみることをお勧めします。