20
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

株式会社VISIONARY JAPANAdvent Calendar 2024

Day 6

初心者向け -lambdaとAPIGatewayを使用してDynamoDBにデータ登録-

Last updated at Posted at 2024-12-06

この記事では、AWSのサーバーレス機能である Lambda と API Gateway を組み合わせて、DynamoDB にデータを登録する仕組みを構築します。
Lambda は、イベント駆動型でコードを実行できるサーバーレスコンピューティングサービスで、API Gateway を通じて外部リクエストを処理する役割を果たします。以下の手順で進めていきます。

1.DynamoDBテーブルを作成する
2.Lambda関数を作成する
3.API Gatewayを設定する

Lambdaとは

LambdaとはAmazon Web Services(AWS)が提供するサーバーレスコンピューティングサービスであり、Java、Node.js、C#、Pythonといったプログラミング言語に対応しています。
Lambdaは、ファイルのアップロードやデータストリームなどのイベントに応じて起動し、データ処理を自動で実行するタスクに最適です。
Lambda関数は必要なときにのみ実行されるため、リソースを無駄にせず効率的に処理を行えます。これにより、コスト削減とシステムの効率化が期待できます。

API Gatewayとは

AWS API Gatewayは、クライアント(アプリケーション)とバックエンドサービス(サーバー上のサービス)の間をつなぐAPI管理ツールです。あらゆる規模のREST、HTTP、WebSocket APIを作成、公開、管理、モニタリング、セキュア化するために利用されます。API Gatewayを利用すると、APIリクエストに応じてAWS Lambdaのコードを実行し、その結果をレスポンスとして返す仕組みを構築できます。これにより、サーバーやデータベースの管理を意識せず、柔軟でスケーラブルなアプリケーションを簡単に開発できます。

DynamoDBとは

Amazon DynamoDBは、サーバーレスのフルマネージドNoSQLデータベースです。リレーショナルデータベースと比べて、非構造化データの処理やスケーラビリティに優れ、ショッピングカートなど大規模なオペレーションワークロードにも適しています。代表的な特徴として、サーバー管理が不要、ストレージ容量が無制限、可用性の向上、コスト効率の良さなどが挙げられます。また、AWSがSQL互換のクエリ言語を提供するため、柔軟に活用できるのも魅力です。リレーショナルデータベースの複雑さを軽減しながら、運用効率を高める選択肢として最適です。

1.DynamoDBテーブルを作成する

まずはDynamoDBのテーブルを作成します。
AWSにログインして左上の検索ボックスから「DynamoDB」と間絵作をかけ、画面が表示されたら「テーブルの作成」を選択します。
すると下記の画面になるので、テーブル名を入力します。
ソートキーは必須ではないので、必要であれば入力しましよう。今回は、パーテンションキーのみ入力します。パーテンションキーに入れる値が数値の場合は右の文字列の立っているボックスを変更しましょう。
入力したら下の「テーブルを作成」ボタンを押下します。
image.png

数秒待つと、状態が「アクティブ」になります。この状態になれば、テーブルの作成が完了です
image.png

2.Lambda関数を作成する

次に、Lambda関数を作成します。
左上の検索ボックスで「Lambda」と検索し、「関数の作成」を選択します。
image.png

関数名を入力し、ランタイムを選択します。
ランタイムとは、Python、Node.jsなどのプログラミング言語を選択する項目です。
今回はNode.jsを選択し、関数を作成します。
image.png

次に、関数コードを記述します。

index.js
const AWS = require('aws-sdk');
const dynamoDb = new AWS.DynamoDB.DocumentClient();

exports.handler = async (event) => {
    try {
        // リクエストボディを取得
        const data = JSON.parse(event.body);

        // 必須データの検証
        const requiredFields = ['id', 'date', 'dayOfWeek', 'title', 'body', 'registeredUser'];
        const missingFields = requiredFields.filter(field => !data[field]);

        if (missingFields.length > 0) {
            return {
                statusCode: 400,
                body: JSON.stringify({
                    message: `Missing required fields: ${missingFields.join(', ')}`,
                }),
            };
        }

        // DynamoDBに登録するデータ
        const params = {
            TableName: 'TaskSchedule', // DynamoDBテーブル名
            Item: {
                id: data.id,                   // パーティションキー
                date: data.date,               // 日付 (ISO形式: YYYY-MM-DD)
                dayOfWeek: data.dayOfWeek,     // 曜日 (例: "Monday")
                title: data.title,             // タイトル
                body: data.body,               // 本文
                registeredAt: new Date().toISOString(), // 登録日時
                registeredUser: data.registeredUser,    // 登録ユーザー
                updatedAt: null,              // 初期値はnull
                updatedUser: null,            // 初期値はnull
            },
        };

        // DynamoDBにデータを登録
        await dynamoDb.put(params).promise();

        return {
            statusCode: 200,
            body: JSON.stringify({
                message: 'Task added successfully',
                task: params.Item,
            }),
        };
    } catch (error) {
        console.error('Error:', error);
        return {
            statusCode: 500,
            body: JSON.stringify({
                message: 'Error adding task',
                error: error.message,
            }),
        };
    }
};

次に、LambdaがDynamoDBにアクセスできるようにアクセス権限を設定します。
まず、作成したLambda関数を選択し、「設定」タブからロール名を確認しておきましょう。
image.png

左上の検索バーで「IAM」と検索し、左側のメニューから「ロール」を選択します。
一覧にロールが表示されるので、先ほど確認したLambdaのロール名を選択してください。
※該当のロールが見つからない場合は、Lambda関数を再作成して確認してください。

image.png
許可ポリシーのセクションで「許可を追加」をクリックし、「ポリシーをアタッチ」を選択します。
image.png

検索ボックスに「AmazonDynamoDBFullAccess」と入力し、表示された項目のチェックボックスをオンにします。
右下の「許可を追加」ボタンをクリックしてください。

image.png
許可ポリシーに「AmazonDynamoDBFullAccess」が追加されていることを確認します。
その後、Lambda関数のコードをデプロイして、Lambda関数の作成は完了です。

3.APIGatewayを設定する

次に、API Gatewayを設定します。
画面左上の検索バーで「API Gateway」と検索し、API Gatewayサービスに移動します。その後、「APIを作成」をクリックします。
image.png
「APIタイプを選択」と表示されるので、「HTTP API」または「REST API」を選択してください。(ここではREST APIを使用します)
「新しいAPI」を選択し、API名を入力したら、画面右下の「APIを作成」をクリックします。
image.png

APIが作成されたら、次にリソースを作成します。
画面中央の「リソースの作成」をクリックします。

リソース作成画面

リソース名を入力し、画面右下の「リソースを作成」をクリックしてください。

image.png

次に、画面右側の「メソッドの作成」をクリックします。
メソッドタイプは「POST」、統合タイプは「Lambda関数」を選択します。

画面下部に表示されるLambda関数の指定欄に、先ほど作成したLambda関数を入力します。関数名を一部入力すると、自動で候補が表示されるので、その中から該当の関数を選択してください。
メソッド作成画面

その後、画面右上にある「APIをデプロイ」をクリックします。
ステージの設定画面が表示されたら、「新しいステージ」を選択し、ステージ名を入力して、画面右下の「デプロイ」をクリックします。
デプロイ画面

これで、API Gatewayの設定は完了です。
では、Lambda関数を動かして、DynamoDBにデータ登録してみます。

image.png

次に、「Create test event」をクリックして、テストイベントを作成します。
イベント名(EventName)を入力し、以下のJSONデータを貼り付けます。

{
  "body": "{\"id\":\"123\",\"date\":\"2024-12-06\",\"dayOfWeek\":\"Monday\",\"title\":\"Sample Task\",\"body\":\"This is a sample task.\",\"registeredUser\":\"User1\"}"
}

入力が完了したら保存し、「Test」をクリックします。

実行後、以下のようなレスポンスが返ってくれば成功です。

Response:
{
  "statusCode": 200,
  "body": "{\"message\":\"Task added successfully\",\"task\":{\"id\":\"123\",\"date\":\"2024-12-06\",\"dayOfWeek\":\"Monday\",\"title\":\"Sample Task\",\"body\":\"This is a sample task.\",\"registeredAt\":\"2024-12-06T04:24:53.117Z\",\"registeredUser\":\"User1\",\"updatedAt\":null,\"updatedUser\":null}}"
}

もし、この時点で aws-sdk 関連のエラーが発生する場合は、以下の記事を参考にしてください。

最後に、DynamoDBにデータが登録されているか確認してみましょう。

image.png

登録されたデータがDynamoDBに反映されていれば、設定は成功です!

エラーが発生した場合

もしエラーが発生した場合は、CloudWatch でログを確認すると原因を特定しやすくなります。
Lambda関数のログを確認するには、Lambdaの詳細画面から「モニタリング」をクリックし、「CloudWatchログを表示」を選択してください。以下のような画面が表示され、詳細なログ情報を確認できます。

image.png

この記事が、これからAWSを活用して開発を始める方の参考になれば幸いです。ぜひ試してみてください!

20
2
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
20
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?