0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

【初心者向け】LambdaからS3へファイルをアップロードする

Posted at

はじめに

これまでMicrosoft Azureを触ってきましたが、転職に伴いAWSの知識が必要になったため、最低限の基本知識をキャッチアップすべく、自己学習を始めました。今回はさらに理解を深める目的で学習した内容をアウトプットします。初心者向けの内容となっておりますので、温かい目で見て頂ければ幸いです。

ポイント

今回はAWSのサービスを知ることが一番の目的であったため、最小労力でできるだけシンプルに作ることを意識しました。ローカルの環境構築などは一切不要で、AWSのコンソール上ですべて完結する手順となります。(12ヵ月無料枠の環境を利用)

利用するAWSサービス

  • Lambda (Python3.13)
  • S3
  • IAM

実践手順

S3にバケットを用意する

コンソール上でS3を選択し、ファイルをアップロードする格納先を作成します。バケット名はグローバルで一意な名前である必要があります。バケット名以外はデフォルトでOKです。
※「パブリックアクセスをすべてブロック」がオンになっていることが大事なポイントです。
image.png

これでS3側の設定は完了です。

IAMロールを作成する

AWSではサービス間のアクセスを可能とするために、権限を付与する必要があります。権限の作成や管理はIAMというサービスを使って実施します。

  1. ユースケースを選択する
    IAMからロールを選択し、新規にロールを作成します。今回は、LambdaからS3へのアクセスを許可するロールを作成するため、ユースケースには「Lambda」を選択します。
    image.png

  2. ポリシーを追加する
    ロールにアタッチするポリシーを追加します。S3にファイルをアップロードする権限が必要なため、「AmazonS3FullAccess」を選択します。
    ※今回は最小労力で構築するため事前に用意されているAWSの管理ポリシーを使用しましたが、アップロードのみの操作や特定のバケットを対象としたポリシーを独自に作成して付与することでセキュリティ性が向上します。
    image.png

  3. ロールを作成する
    ロール名を入力し、ロールを作成します。作成したロールは後述のLambda関数で利用するため、分かりやすい名前にします。
    image.png

これでIAMロールの作成は完了です。

Lambda関数の作成

  1. 関数を作成する
    今回はPythonでプログラムを書くため、ランタイムは「python 3.13」を選択します。
    関数名はプログラムの内容がイメージしやすい名前にします。
    ロールは後で設定するので、ここではデフォルトのままとします。
    image.png

  2. タイムアウト時間を設定する
    設定タブの「一般設定」からタイムアウト時間を設定します。デフォルトの仕様が3秒であるため、必要な時間に変更します。今回は10秒に変更します。
    image.png

  3. 実行ロールを設定する
    S3へのアクセスに必要なロールを付与します。前述で作成したIAMロールをリストから選択します。
    image.png

  4. 環境変数を設定する
    設定タブの「環境変数」を選択し、プログラムから参照する変数を定義します。今回はアップロード先となるS3のバケット名とアップロードするファイル名を定義します。
    ※必須ではないです。後述するコード上に直接記載する場合は、本手順は不要です。
    image.png

コードの作成と実行

S3へファイルをアップロードするコードをLambdaのエディタ上で書いていきます。以下はサンプルコードです。
※今回コードの説明は割愛しますが、pythonからAWSのサービスを操作する便利なライブラリが「boto3」になります。Lambdaにはデフォルトでboto3がインストールされているため、そのまま利用することができます。

サンプルコード

import boto3
import os

def lambda_handler(event, context):
    # S3バケット名と保存するファイル名を環境変数から取得
    s3_bucket_name = os.environ['bucket_name']
    s3_file_name = os.environ['file_name']
    
    # テキストデータを定義
    text_data = "S3へファイルをアップロードするテスト"

    # 一時ディレクトリにファイルを作成 
    temp_file_path = f"/tmp/{s3_file_name}"
    with open(temp_file_path, "w", encoding="utf-8") as file:
        file.write(text_data)

    # S3クライアントを作成してファイルをアップロード
    s3 = boto3.client('s3')
    try:
        s3.upload_file(temp_file_path, s3_bucket_name, s3_file_name)
        return {
            'statusCode': 200,
            'body': f"ファイル '{s3_file_name}' が S3 バケット '{s3_bucket_name}' に正常にアップロードされました。"
        }
    except Exception as e:
        return {
            'statusCode': 500,
            'body': f"エラーが発生しました: {str(e)}"
        }
  1. デプロイ
    Deployボタンを押下して、作成したコードをLambdaにデプロイします。
    image.png
    以下のメッセージが画面上に表示されたら、デプロイは正常に完了です。
    image.png

  2. テスト
    テストタブより、「テスト」ボタンを押下しコードを実行します。
    image.png

  3. 実行結果
    Lambdaの関数が正常に動作したことを確認できました。
    image.png
    S3の指定したバケット内にファイルが出力されていることも確認できました。
    image.png

おわりに

初めてAWSを触った所感ですが、参考となる文献や情報が多く比較的容易にやりたいことを実現できました。また、GUIや操作感もエンジニアライクな仕様となっており、理解しやすかった印象です。第一歩として、主要なサービスかつ超シンプルな仕組みを構築しましたが、今後さらに拡張したり他のサービスと組み合わせてみたり、いろいろトライしていこうと思います。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?