はじめに
AWS ECSのタスクをイベント駆動型に動かしてみます。今回は「特定のS3バケットにオブジェクトがアップロードされた場合」に起動するように設定します。
参考:
ちなみに、イベント駆動型以外にもスケジュール型が存在しており、バッチのようにタスクを動かすことも可能です。
設定方法
前提条件
ECSの設定(Cluster,Task定義..etc)とS3バケットの作成が完了していること。
CloudTrailが有効化されていること。
EventBridgeの設定
-
コンソールにアクセスし、ルールを作成する。
-
「パターンを定義」では以下の通りに設定する。
{
"source": ["aws.s3"],
"detail-type": ["AWS API Call via CloudTrail"],
"detail": {
"eventSource": ["s3.amazonaws.com"],
"eventName": ["PutObject"],
"requestParameters": {
"bucketName": ["<Your S3 Bucket>"]
}
}
}
detail-typeから察するに、トリガーはCloudTrailのイベントのよう。
- 「ターゲットを選択」では以下のように設定する
- ターゲット:ECSタスク
- クラスター:タスクをデプロイしたいクラスター
- タスク定義:デプロイしたいタスクのタスク定義
- タスク定義リビジョン:デプロイしたいタスクのリビジョン
- カウント:デプロイしたいタスク数
- 「コンピューティングオプション」/「ネットワーク設定を構成する」では自環境にあったものを設定する
- 「追加プロパティを設定」は最近追加されたようです
- 自環境に合うように設定する
※Fargate起動タイプを使用する場合はタスク配置戦略/配置拘束はサポートされません。
- タスクグループ:複数のタスクをひとまとまりとする。配置戦略などでセットとしてみなされる。
- 配置拘束:タスク配置時に考慮されるルール。
- distinctInstance:タスクグループ内の各タスクを別のインスタンスに配置する。
- memberOf:式を満たすコンテナインスタンスにタスクを配置する。
- 配置戦略:コンテナインスタンスにタスクを配置する方法。
- binpack:インスタンス数を最小限に抑える。
- random:ランダムに配置する。
- spread:指定された値に基づいて均等に配置する。
- 管理タグを設定:マネージドタグを自動的にタグ付けするかどうか。
- 実行コマンドを設定:Amazon ECS Execを使用するかどうか。
- 伝搬タグを設定:タスク定義からタグを伝搬するかどうか。
参考:
https://docs.aws.amazon.com/ja_jp/AmazonECS/latest/developerguide/task-placement.html
- ロールの作成・リトライの設定をしたのち、作成する
試す
対象のS3バケットに適当なファイルを配置する
-
ECSのコンソールから確認する
- タスクが立ち上がっている
- 開始元がEventBridgeで作成したルールとなっている
イベントがトリガーされない場合
「CloudTrail - 証跡」から、データイベントが有効化されていることを確認してください。
まとめ
特定のS3バケットにオブジェクトが配置されたらタスクを実行するという設定を行いました。「S3に何か行われた際に何かする」というユースケースの場合、Lambdaを使う場合が多いかなという気もしますが、ECSを使うこともできるということも頭の片隅に入れておきたいですね。