AWS Lambdaとは
AWS Lambda(エーダブルエス・ラムダ)は、サーバレス・システムの一つで、何らかのプログラムなどによる処理を行う際に、実行環境となるサーバを用意することなくそのプログラムを実行する環境を提供する新しい技術です。
特に、バッチ処理やオフライン処理を実行するのに適しています。
また、AWS Lambdaの実行基盤となるインフラ面(サーバリソースなど)はAWSが管理しているために、この部分についてのメンテナンス作業は不要で、利用側としては実行対象となるソースのみに集中すれば良く、コスト面・運用面でもメリットがあります。
本記事執筆時点で実行できるプログラムとして、Java、Go、PowerShell、Node.js、C#、Python、Rubyがあります。
ただし、処理の実行可能時間には上限があり、最大15分となっています(2020年8月現在)。
この記事の目的
本記事では、AWS Lambdaを実行するためのAWSの環境設定と実行方法を確認したいと思います。
実行するプログラムとして、Python言語で文字列"Hello world."を出力するプログラムを用意し、Lambda関数として登録します。
そしてこのLambda関数を、AWSサービスをコマンドプロンプトから使用できるAWS CLIで実行し、その結果をS3(エススリー)にテキストファイルで格納する手順とします。
※AWS CLIはコマンド・ライン・インターフェースの略です。
※S3はSimple Storage Serviceの略で、AWSが提供するストレージサービスのことです。
本記事の情報は、執筆2020年8月現在のものです。AWSのサービス内容は常に更新されますので、AWSのWEBサイトで最新情報を確認して下さい。
Lambdaを実行すると料金が発生します。
Lambda関数を作成する
AWS Lambdaを実行するとは、Lambda関数を実行することを意味します。よって、Lambda関数の作成から始めます。
前提条件として、AWSアカウントをすでに作成していることとします。
####①Lambda関数を新規作成する
(1) AWSマネジメントコンソール画面の上部のメニューから「サービス」→「コンピューティング」→「Lambda」を選択します(下図赤下線)。
(3) 関数の作成オプションとして、「一から作成」を選択して下さい(デフォルトで選択されています)。
(4) 基本的な情報を設定します。
ここでは、以下の通り設定しました。
設定項目 | 設定内容 |
---|---|
関数名 | my_lambda_function |
ランタイム | Python 3.8 |
アクセス権限の設定はデフォルトのままで構いません。
右下の「関数の作成」ボタンをクリックします。
Lambda関数が作成され、画面が切り替わります。
(5) Lambda関数を実装します。
画面が切り替わると以下の画面となります。
さらに下に進むと、下図のようなソースの編集枠が現れます。
ここがLambda関数の実態になります。ここに実行したい処理を記述します。
今回はS3へファイルを格納するため、ソースを以下のように実装しました。
※バケット名やオブジェクト・キー名は実際に使用する値に設定して下さい。
import boto3
# S3オブジェクトを取得
s3 = boto3.resource('s3')
# Lambdaが実行するプログラム本体の関数
def lambda_handler(event, context):
# バケット名を指定
bucket = 'tabata.myfirstbucket'
# オブジェクトキーの定義(Lambdaがバケット内に書き出すファイル名に相当)
key = 'lambda_outpu.dat'
# ファイルに書き出す文字列
puttext = 'Hello world.'
# バケット名とオブジェクトキーを設定
obj = s3.Object(bucket,key)
# ファイルに書き出す文字列を設定
obj.put(Body=puttext)
# 関数終了
return
####②S3バケットへアクセスするIAMロールを作成する
Lambda関数からS3バケットへのアクセスを許可するためのIAMロールを作成し、Lambda関数に付与します。
(1) AWSマネジメントコンソール画面の上部のメニューから「サービス」→「セキュリティ、ID、およびコンプライアンス」→「IAM」を選択します(下図赤枠)。
(2) 左枠のメニューから「ロール」を選択します。
(3) 「ロールの作成」を選択します。
(4) 下図を参考に、ユースケースとして「Lambda」を選択し、「次のステップへ」ボタンをクリックして下さい。
(5) 下図を参考に、アタッチするアクセス権限ポリシーを選択します。
緑色枠のように、検索欄に"lambda"と入力します。
赤色枠の通り「AWSLambdaBasicExecutionRole」にチェックを入れて下さい。
「次のステップ」ボタンをクリックします。
(6) タグ名を設定します。
必要であれば、タグ名を入力して下さい。
「次のステップ」ボタンをクリックします。
(7) ロール名を設定します。
ロール名を「lambda-role」としました。
「ロールの作成」ボタンをクリックします。
####③作成したIAMロールにS3バケットへのアクセス権ポリシーを付与する
(1) 下図の通り、作成したIAMロールを選択します。
(2)「アクセス権限」タブ内の「インラインポリシーの追加」を選択します。
(3) 下図の通り、サービス項目「サービスの選択」をクリックします。
(4) サービス名から「S3」を選択して下さい。
(5) 下図の通り、アクション項目で「アクセスレベル」として「書き込み」にチェックを入れて下さい。
(6) リソースとして「すべてのリソース」を選択するか、またはbucketのみ許可して下さい。
(7)「ポリシーの確認」ボタンをクリックします。
(8) ポリシーの確認画面で任意の名前を入力して下さい。
ここでは「lambda_function_policy」としました。
最後に「ポリシーの作成」をクリックします。
(9) 付与したポリシーが表示されていればOKです。
####④IAMロールをLambda関数の実行ロールとして設定する
(1) AWSマネジメントコンソール画面の上部のメニューから「サービス」→「コンピューティング」→「Lambda」を選択します(下図赤枠)。
(2) 作成したLambda関数を選択して下さい。
(3) 下図の通り、「アクセス権限」タブを選択し、「編集」ボタンをクリックして下さい。
(4) 下図を参考に、「説明 - オプション」欄が空欄の場合は入力して下さい。
(5) 下図を参考に入力して下さい。
・メモリ容量の調整が必要な場合は、修正して下さい。
・タイムアウトの調整が必要な場合は、修正して下さい。
・既存のロールで、作成したロールを選択して下さい(赤枠)。
最後に「保存」ボタンをクリックして下さい。
####⑤Lambda関数の実行テスト
作成したLambda関数が実際に実行されるか、テストします。
(1) 下図の通り、「テスト」ボタンを選択して下さい。
(2) 「イベント名」を入力して下さい(任意の名前)。
(3) 「作成」ボタンをクリックして下さい。
(4) 「テスト」ボタンを選択して下さい。
(5) テスト結果を確認します。
特にエラーが発生していなければテストはOKです。
※念のため、S3バケットにファイルが格納されたことを確認して下さい。
※ファイルの内容に「Hello world.」と記載されていればLambda関数の作成は完了です。
AWS CLIからLambdaを実行する
Lambda関数の作成は完了しましたので、実際にコマンドプロンプトからLambda関数を実行します。
コマンドプロンプトでAWS CLIが使用できることを予め確認します。
aws --version
####①awsコマンドの事前設定を行う
以下のコマンドを実行して事前設定を行います。
aws configure
入力項目は以下となります。
(1)アクセスキーID(Access Key ID)
(2)シークレットアクセスキー(Secret Access Key)
上記(1)(2)の確認方法は、以下を参考にして下さい。
■AWS S3の始め方 ~ バケットにファイルを格納する
→「②アクセスキーIDとシークレットアクセスキーの作成」の章
https://qiita.com/ttlabo/items/ea802f98418d229681fb
(3)Default region name
実行するリージョンを設定します。ここでは ap-northeast-1 としました。
(4)Default output format
関数の実行後のレスポンスのデータ形式を指定します。ここでは json としました。
####②Lambda関数を実行するコマンド
Lambda関数を実行するためのコマンドは以下です。
aws lambda invoke --function-name my_lambda_function --payload '{ "key": "" }' response.json
コマンドの意味は以下です。
--function-name
実行するLambda関数名を指定します。
--payload
入力パラメータです。今回はパラメータ無しのため、key=""としています。
response.json
AWS CLIが関数からのレスポンスを書き込むファイルの名前です。
####③awsコマンドでLambda関数を実行する
上記のaws lambda...コマンドを実行します。
実行後、Lambda関数の処理によりS3にファイルが格納されればOKです。
関連情報
■Lambda 実行ロールに Amazon S3 バケットへのアクセスを許可するにはどうすればよいですか?(AWS公式ドキュメント)
https://aws.amazon.com/jp/premiumsupport/knowledge-center/lambda-execution-role-s3-bucket/
■AWS S3の始め方 ~ バケットにファイルを格納する
https://qiita.com/ttlabo/items/ea802f98418d229681fb
ご意見など
ご意見、間違い訂正などございましたらお寄せ下さい。