https://github.com/heiwa4126/sam-s3event1
1つのスタックを2回にわけてデプロイしないといけないSAMのサンプル
https://github.com/heiwa4126/sam-s3event1
aws-sam example
Last synced: 4 days ago
JSON representation
1つのスタックを2回にわけてデプロイしないといけないSAMのサンプル
- Host: GitHub
- URL: https://github.com/heiwa4126/sam-s3event1
- Owner: heiwa4126
- Created: 2022-10-18T06:00:58.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2022-10-18T07:10:34.000Z (over 3 years ago)
- Last Synced: 2025-01-04T16:18:44.325Z (over 1 year ago)
- Topics: aws-sam, example
- Language: Shell
- Homepage:
- Size: 17.6 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# sam-s3event1
S3イベントをトリガにしてlambdaを起動する。
だがそのlambdaはイベント元のS3に依存している、という場合、
1つのスタックを2回にわけてデプロイしないといけない、
というSAMのサンプル。
参考:
[AWS::S3::Bucket NotificationConfiguration - AWS CloudFormation](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-s3-bucket-notificationconfig.html) の冒頭のnote参照。
上記該当部分の機械翻訳(DeepL)
> 対象リソースと関連するパーミッションを同じテンプレートで作成した場合、循環的な依存関係が発生する可能性があります。
>
> 例えば、AWS::Lambda::Permissionリソースを使用して、バケットにAWS Lambda関数を呼び出す権限を付与することができます。しかし、AWS CloudFormationはバケットに関数を呼び出す権限がないとバケットを作成できません(AWS CloudFormationはバケットが関数を呼び出すことができるかどうかをチェックします)。Refsを使ってバケット名を渡している場合、これは循環依存につながります。
>
> この依存関係を回避するには、通知設定を指定せずにすべてのリソースを作成します。その後、通知設定を使ってスタックを更新します。
# デプロイ
```bash
./1to0.sh # template.yamlからtmp0.yaml(最初のデプロイ用テンプレート)を生成する
sam build
sam deploy -t tmp0.yaml -g # 全部デフォルトで(returnキーを押すだけ)。2回目からは-g(--guided)ぬきで
sam deploy
```
# テスト
デプロイ終了後
```bash
./make_env.sh # デプロイ毎に1回実行
./tail_samlog.sh # tmuxなどで別ペインで実行するのがおすすめ
```
で、
```bash
./put_s3.sh
```
すると、しばらく(10秒ぐらい?)たってから最新ログが表示される。
```bash
./rm_s3.sh && ./put_s3.sh
```
で何度でもテストできる。
# スタックの削除
```bash
./stop_samlog.sh
./rm_s3.sh
sam delete --no-prompts
```
# ポイント
template.yaml も
tmp0.yaml も
循環依存(circular dependency)があってはいけない。
事前に [cfn-lint](https://github.com/aws-cloudformation/cfn-lint)でチェックしておくべき。
このケースでは
[AWS::Serverless::Function](https://docs.aws.amazon.com/ja_jp/serverless-application-model/latest/developerguide/sam-resource-function.html#sam-function-events) の
[S3イベント](https://docs.aws.amazon.com/serverless-application-model/latest/developerguide/sam-property-function-s3.html)
も使えない。
# TODO
template.yaml から
template0.yaml を自動生成できるような工夫を考えること
-> done. `1to0.sh`がそれ。
あとTerraformではどうなのか確認すること。