11
9

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

StudyCoAdvent Calendar 2021

Day 3

ServerlessFrameworkでDynamoDBLocalを使う

Last updated at Posted at 2021-12-02

今更ですが、Serverless FrameworkでDynamoDBのローカル開発環境を構築するために、DynamoDB Localを導入したので、その記録です。

はじめに

DynamoDB Local 自体は、そもそも aws 公式のツールです。

DynamoDB をローカル環境で利用できるように用意されています。

JRE 上で動作するので、Java6以上の実行環境が必要です。1

それを Serverless Framework で使うための Serverless DynamoDB Local というプラグインがあります。

プラグインを利用しなくても DynamoDB Localを利用することはできますが、serverless frameworkの設定と一緒にかけたり、seedなどのオプションがあり便利です。

Serverless Framework で DynamoDB Local の導入手順

プラグインをインストールします。

# Serverles DynamoDB local pluginの依存モジュールのインストール
npm install -D serverless-dynamodb-local

次に、serverless.ymlserverless-dynamodb-local の plugin の指定を入れます。

serverless-webpackserverless-offlineのプラグインを一緒に利用するときは、以下の順番で指定します。

plugins:
  - serverless-webpack
  - serverless-dynamodb-local
  - serverless-offline

Serverles DynamoDB local プラグイン のインストール後に、DynamoDB Local 本体をインストールします。
プラグインをインストールすると、以下のコマンドで DynamoDB Local をインストールできます。

# dynamodb local のインストール
sls dynamodb install

インストールが完了すると、 .dynamodb ディレクトリが作成され、jarなどが配置されます。

sls dynamodb start のコマンドで、DynamoDB Localが起動します。

あとは 以下で設定するポートに対してアクセスして(例: https://localhost:8000)利用するかんじになります。ソースコードからや、awscliからの利用方法は後述します。

DynamoDB Local の設定

inMemoryで起動したり、初期データ作成をするためのオプションが提供されています。

以下のように serverless.ymlcustom での設定も可能で、公式にオプションの説明があるので、細かく設定したい時に見ると良さそうです。

custom:
  dynamodb:
    stages:
      - dev
    start:
      port: 8000
      inMemory: true
      migrate: true
      seed: true
      convertEmptyValues: true

serverless-offlineと起動

Serverless Framework のローカル開発環境では、よく serverless-offline を利用していると思います。

serverless-offlineと一緒に利用していれば、 sls offline で DynamoDB Local も一緒に起動してくれます。2

serverless-webpackも使っている場合は、sls offline start で起動する必要があります。

逆にDynamo Localを個別に起動しておきたい場合 は、 上述の serverless.yml のcutom 設定で、 noStart: true を設定することで、 sls offlineで Dynamo Local が一緒に起動しなくなります。

ソースコードからの利用方法

ローカル開発時だけ、DynamoDB Local に向けて、AWSにプロビジョニングしたときは本物のDynamoDBに接続したいときは、ソースコード上で向き先を変更する必要があります。

これは、Serverless Frameworkのサンプルコードなどを参考にするといいでしょう。

オフラインかどうかの判定は、sls offline を起動すると、IS_OFFLINEの環境変数が設定されるので、それをみて接続先を切り替えます。

AWS CLI でのコマンド実行

ローカル開発中に、DynamoDB Localに入っているデータを閲覧、編集、削除などしたい場合があると思いますが、awscliでエンドポイントを指定すれば簡単に操作することができます。

# table一覧
aws dynamodb list-tables --endpoint-url http://localhost:8000

# 指定したテーブルをscan
aws dynamodb scan --table-name <table名>  --endpoint-url http://localhost:8000

また、ブラウザ上で操作ができる「JavaScript console」なるもの用意されていて、以下のようにリンクが表示されるんですが、自分の環境ではアクセスしても表示されなかったです。(原因がわかったら追記します。)

$ sls dynamodb start
Dynamodb Local Started, Visit: http://localhost:8000/shell

その他

  • 上記はDynamoDB Localの設定方法の説明なだけで、DynamoDBのテーブル定義は、別途 Resouces で設定する必要があります。CloudFormationの構文で書いていくだけです。
  • serverless.ymlserverless.ts の設定は、npx sls print で正しいかチェックできるので利用すると良いでしょう。
  1. Docker イメージもあるようで、docker でも動作させることができます。

  2. serverless.yml での serverless-offline プラグインの指定を最後に書く必要があります。

11
9
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
11
9

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?