記事のターゲット
- S3へ置かれたファイルを使用して処理を実装したい方
- Lambda側で処理を完結させたい方
S3バケットの作成
data:image/s3,"s3://crabby-images/d5d02/d5d02a9451e795b7b25fbfe885786d2d79b01567" alt=""
バケット名とリージョンを指定し、その他はいったんデフォルトで作成。
data:image/s3,"s3://crabby-images/369d6/369d691ed6c067c799044cd786a4e5a0da65bc1e" alt=""
Lambda関数の作成
data:image/s3,"s3://crabby-images/f942b/f942b75852a375b6ae5e1d5da0c75456590e7773" alt=""
設計図でGet S3 Objectを選択すると最初からデータ取得のコードが記述された状態で関数が作成される。
data:image/s3,"s3://crabby-images/bd14f/bd14f154aac11da844b9abeec9ca0bcf58c8fe95" alt=""
ロールは無ければ作成する。この際、S3の読み取り権限を付与する。
data:image/s3,"s3://crabby-images/de051/de0518b958a28015e7f1b5fdc10af61683dd28d9" alt=""
最後のトリガー部分では先ほど作成したバケット名を指定してEvent TypeにはPUTを指定する。S3に置かれるファイルが巨大になる想定の場合はMultipart upload completedも指定しないとLambdaが起動しないことがある。
data:image/s3,"s3://crabby-images/77073/77073f7f8d31a5385a7a38fe0568de7b070c9c65" alt=""
チェックを付けているI acknowledge~の部分は、PUTトリガーされたS3にLambdaの処理でまたファイルをPUTする場合無限ループになるのわかってますか?という問いなので理解出来たらチェックを入れる。
チェックしないと関数が作成できない。
data:image/s3,"s3://crabby-images/101c3/101c392e4426950727bafd90fd5c0acc8853ca8c" alt=""
作成すると上記のように最初からある程度のコードが記述された状態になる。
19行目のgetObjectでS3からPUTされたファイルを取得している。ファイルに処理を行いたい場合はこの部分を変更する。
今回は取得したファイル内容を新たに作成したファイルに書き込んでPUTされたバケットとは別のバケットにPUTする処理を作成する。
新たにS3バケットを作成。
data:image/s3,"s3://crabby-images/72c25/72c25a474f5b21581f7d040b9aea830f0b1d6b87" alt=""
data:image/s3,"s3://crabby-images/4f33d/4f33d41d31ee78b457e2aaf6eb88732bda1411a6" alt=""
test-1111111111111に置かれたファイルをtest-1111111111111-afterにPUTする。
data:image/s3,"s3://crabby-images/94d7f/94d7f43a6fdb56a0cb31c32bf9d5919e6471df9c" alt=""
事前準備として、今のままだとLambdaからS3へのアクセス時にアクセス拒否されるのでLambda側にS3をいじる権限を付与する。
上記のように該当するLambda関数の設定→アクセス権限から実行ロールをクリックする。
ポリシーをアタッチ→AmazonS3FullAccessを選択→ポリシーをアタッチをクリックでS3への権限を与える。
data:image/s3,"s3://crabby-images/82c7c/82c7cbc83c4350bc3cd7d6b869379f3f77391e72" alt=""
data:image/s3,"s3://crabby-images/94fe6/94fe6193aacf0a674e948efc7b87079d3f68d4ed" alt=""
コードの修正
data:image/s3,"s3://crabby-images/8b822/8b8224ea0a9e5b4e72fade0a3bba05101e684d31" alt=""
前提として、コードを修正した際は上記のDeployボタンをクリックすると変更が反映される。
console.log('Loading function');
const aws = require('aws-sdk');
const s3 = new aws.S3({ apiVersion: '2006-03-01' });
exports.handler = async (event, context) => {
//ファイルがPUTされたバケットの情報取得
const bucket = event.Records[0].s3.bucket.name;
const key = decodeURIComponent(event.Records[0].s3.object.key.replace(/\+/g, ' '));
const params = {
Bucket: bucket,
Key: key,
};
try {
//PUTされたファイルを取得
const obj = await s3.getObject(params).promise();
const contents = obj.Body.toString();
console.log("取得したファイル内容:" + contents);
//ファイル内容に何か処理したい場合はここに処理を記述
//次にPUTするバケット名
const nextBucket = "test-1111111111111-after";
const nextKey = "after-sample.json"
const nextBody = contents;
const nextParam = {
Bucket: nextBucket,
Key: nextKey,
Body:nextBody
}
//別バケットにファイル名を変えてPUT
await s3.putObject(nextParam).promise();
} catch (err) {
console.log(err);
const message = `Error getting object ${key} from bucket ${bucket}. Make sure they exist and your bucket is in the same region as this function.`;
console.log(message);
throw new Error(message);
}
};
上記のようにコード変更し、デプロイボタンクリック。
ここまで出来たらtest-1111111111111に以下内容のファイルをPUTする
data:image/s3,"s3://crabby-images/319bf/319bfe9e6b87bf96d70dae6aaec1f413edd8ea11" alt=""
data:image/s3,"s3://crabby-images/7ff8d/7ff8d44372fde7005874bc26a2ac43f1674f9c82" alt=""
PUTしたらtest-1111111111111-afterのバケットを見に行くと
data:image/s3,"s3://crabby-images/9e2e9/9e2e9de401a8fcb1508a63fa239b9ebd159687de" alt=""
after-sample.jsonファイルが作成されていることを確認。
ログが見たければLambdaの該当関数のページ→モニタリング→ログから確認できる。
data:image/s3,"s3://crabby-images/15c42/15c42c223178d821466b1807d943e3afa3216a80" alt=""
以上S3トリガーでLambdaを動かす方法。