storage init
$ copilot storage init
コマンドの概要
copilot storage init
は、Addon として新しいストレージリソースを作成します。
デフォルトでは、Copilot は「Database-per-service パターン」に従っています。
copilot storage init
で指定した Service または Job だけが、そのストレージリソースにアクセスできます。
ストレージは、Service のコンテナ内から、ストレージリソースの名前またはリソースにアクセスするためのクレデンシャル情報を保持する環境変数を介してアクセスできます。
各ユーザーには独自の状況があります。データストレージを複数の Service 間で共有する必要がある場合は、Copilot で生成された CloudFormation テンプレートを変更して、目的を達成することができます。
ストレージリソースは、ワークロード Addonとして作成することができます。
これは、Service や Job の1つにアタッチされ、ワークロードと同時にデプロイされ削除されます。
例えば、copilot svc deploy --name api
を実行すると、リソースは「api」とともにターゲット Environment にデプロイされます。
また、ストレージリソースは Environment Addon として作成することができます。
Environment に関連づけられ、Environment と同時にデプロイされ削除されます。
例えば、copilot env deploy --name test
を実行すると、test という Environment と一緒にリソースがデプロイされます。
リソースの種類は S3、DynamoDB、Aurora のいずれかを指定できます。
このコマンドを実行すると、CLI は copilot/service
ディレクトリ内に、addons
サブディレクトリが存在しなければ作成します。copilot svc deploy
を実行すると、新規に初期化されたストレージリソースが、デプロイ先の Environment に作成されます。デフォルトでは、storage init
で指定した Service のみが、そのストレージリソースにアクセスできます。
フラグ
Required Flags
-l, --lifecycle string Whether the storage should be created and deleted
at the same time as an workload or an environment.
Must be one of: "workload" or "environment".
-n, --name string Name of the storage resource to create.
-t, --storage-type string Type of storage to add. Must be one of:
"DynamoDB", "S3", "Aurora".
-w, --workload string Name of the service/job that accesses the storage resource.
DynamoDB Flags
--lsi stringArray Optional. Attribute to use as an alternate sort key. May be specified up to 5 times.
Must be of the format '<keyName>:<dataType>'.
--no-lsi Optional. Don't ask about configuring alternate sort keys.
--no-sort Optional. Skip configuring sort keys.
--partition-key string Partition key for the DDB table.
Must be of the format '<keyName>:<dataType>'.
--sort-key string Optional. Sort key for the DDB table.
Must be of the format '<keyName>:<dataType>'.
Aurora Serverless Flags
--engine string The database engine used in the cluster.
Must be either "MySQL" or "PostgreSQL".
--initial-db string The initial database to create in the cluster.
--parameter-group string Optional. The name of the parameter group to associate with the cluster.
--serverless-version string Optional. Aurora Serverless version. Must be either "v1" or "v2". (default "v2")
Optional Flags
--add-ingress-from string The workload that needs access to an
environment storage resource. Must be specified
with "--name" and "--storage-type".
Can be specified with "--engine".
使用例
"frontend" Service に "my-bucket" という名前の S3 バケットを作成します。
$ copilot storage init -n my-bucket -t S3 -w frontend -l workload
copilot storage init
は、Addon として新しいストレージリソースを作成します。"api" Service がフロントする "my-bucket" という名前の S3 バケットを Environment 単位で作成します。
$ copilot storage init \
-t S3 -n my-bucket \
-w api -l environment
"frontend" Service にアタッチされた "my-table" という名前の基本的な DynamoDB テーブルを、ソートキーを指定して作成します。
$ copilot storage init -t DynamoDB -n my-table \
-w frontend -l workload \
--partition-key Email:S \
--sort-key UserId:N \
--no-lsi
複数の代替ソートキーを持つ DynamoDB テーブルを作成します。
$ copilot storage init -t DynamoDB -n my-table \
+ -w frontend \
--partition-key Email:S \
--sort-key UserId:N \
--lsi Points:N \
--lsi Goodness:N
データベースエンジンに PostgreSQL を使用して、RDS Aurora Serverless v2 クラスタを作成します。
$ copilot storage init \
-n my-cluster -t Aurora -w frontend --engine PostgreSQL
データベースエンジンに MySQL を使用し、初期データベース名を testdb として、RDS Aurora Serverless v1 クラスタを作成します。
$ copilot storage init \
-n my-cluster -t Aurora --serverless-version v1 -w frontend --engine MySQL --initial-db testdb
コマンド内部での動作
Copilot は S3 バケット、DynamoDB テーブル、または Aurora Serverless クラスターを指定する CloudFormation テンプレートを addons
ディレクトリに書き出します
copilot [svc/job/env] deploy
を実行すると、CLI はこのテンプレートを addons
ディレクトリの他のすべてのテンプレートとマージして、Service または Environment に関連するネストされたスタックを作成します。
このネストされたスタックには、Service または Environment に関連付けられたすべての Addon リソース が記述され、Service または Environment がデプロイされる場所に展開されます。
シナリオの例
Service に関連づけられた S3 ストレージ
$ copilot storage init --storage-type S3 --name bucket \
--workload fe --lifecycle workload
Service に関連づけられた S3 バケット用の CloudFormation テンプレートが生成されます。
$ copilot svc deploy --name fe --env test
$ copilot svc deploy --name fe --env prod
このコマンドを実行すると、test Environment と prod Environment の2つのバケットが展開され、それぞれの Environment の fe Service からのみアクセスできるようになります。
Environment に関連づけられた S3 ストレージ
これは、実行後に、
$ copilot storage init --storage-type S3 --name bucket \
--workload fe --lifecycle environment