1
3

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 5 years have passed since last update.

[AWS] Amazon ECS(EC2タイプ)のちょっと長めのチュートリアル(第7回)

Last updated at Posted at 2019-10-30

※本記事は Amazon ECS(EC2タイプ)のちょっと長めのチュートリアル( 第1回 , 第2回 , 第3回 , 第4回 , 第5回 , 第6回 ) の続き(最終回)です。

前回までで、基本的な構築・運用手順は終わりました。

手順はかなり長くなってしまいましたが、これでも端折った機能が多いため、実際にチュートリアルを進めると「ここはデフォルト設定のままだけどどういう意味かな?」と気になる点も出てくるかと思います。最後はそういったポイントについて(ほぼリンク集ですが)まとめておきます。

サービス・タスクのAuto Scale

チュートリアルではタスクは2つで固定していましたが、Scaling Policyを設定することで自動スケールが可能です。 手順は Amazon ECSでAuto Scaling にあります。

また、自動スケールと合わせて行うべき設定としてタスクごとのCPU、メモリ割り当て設定があります。タスク定義内に、タスク全体とコンテナごとの割り当て設定があります。

image.png

クラスター(インスタンス)のAuto Scale

第2回の最後で少し見たように、クラスターのスケールは通常のインスタンスのAuto Scaling Groupと変わりません。
ECS(EC2タイプ)ではここがサービス・タスクのAuto Scaleと連動しないのが辛いところですが、通常のインスタンスと変わらないので SPOTインスタンスの利用もできる のはメリットと言えます。

サービスディスカバリについて

チュートリアルではnginxのコンテナを使ったので、コンテナへのアクセスはELB経由で行いましたが、アプリケーションによってはコンテナに外部から直接アクセスしたい場合もあるかと思います。その場合、コンテナがどこで起動したかを知る仕組みがサービスディスカバリになります。
具体的な手順はこちら にありますが、仕組みとしては、コンテナが正常起動したらRoute53(プライベートホストゾーン)にAレコードを登録してくれるもので、外部からは同じDNS名でのアクセスが可能となります。

設定個所はサービスの新規作成中「サービスの検出」で、サービスの検出名がDNS名です。この設定は今のところサービス作成後に変更できないため、変更する場合はサービスの再作成になります。

13534393235362e706.png

ECSエージェントの更新について

しばらく運用していると、ECSエージェントが最新版でないという警告が出るようになります。

image.png

更新手順はこちらにあります。ECS-optimized AMI であれば ecs-init パッケージを更新するだけです。

AMI更新について

ECSエージェントの更新だけでは、インスタンスの再起動やスケール時にまた古いバージョンで起動してしまうため、ECS-optimized AMIが更新された場合などは起動するAMI自体の更新も必要となります。Auto Scaling Groupの起動設定で変更します。

ECSエージェントの動作設定

Amazon ECS コンテナエージェントの設定 にあるように、環境変数を /etc/ecs/ecs.config ファイルに設定することでエージェントの動作設定が可能です。
ECRイメージまわりの設定(イメージをPullするタイミング、自動イメージクリーンアップの頻度)などもここで設定可能です。

ログ収集について

ログはデフォルトではコンテナ/インスタンスの再起動で消えてしまうため、本番環境では外部に収集する設定が必要となります。ECSのログ収集については検索すると様々な事例が出てきて悩ましいところですが、大きく分けると

  • CloudWatchに送る
  • ログドライバーが対応しているfluentdやsplunkに直接送る
  • 標準出力やファイルに出力して別のログ収集ツールで収集

の3パターンです。検索すれば使い慣れたツールの事例がいくつか出てくると思いますので、調べてみて下さい。

ログドライバーの設定自体はタスク定義のコンテナ設定の中にあります。

image.png

主な注意すべき設定は以上となります。

最後に

チュートリアルで作成した環境を削除します。
サービスとインスタンスは毎回スケールするようにしていましたが、それだけではELBの料金が継続してかかり続けるため、削除しておくようにします。

  • サービスとインスタンス数を0にする

毎回実行していた手順と同じです。第4回の後半 などを参照して下さい。

  • クラスター削除

クラスターの右にある削除ボタンで削除します(サービスとインスタンスが起動しているとここでエラーになる場合があるので事前に0にしておきます)。

image.png

多少時間がかかる場合がありますが待つと削除が完了します。

image.png
  • ELB削除

クラスターの削除では一緒に削除されないため、別に削除します。

image.png

ターゲットグループも個別に削除します。

image.png
  • その他のリソース

ここまでで残るものは VPC、サブネット、ロール、ポリシ です。これらは課金されないので残しても構いませんし、他のリソースと共有している場合は消さないように注意して下さい。
このチュートリアルでしか使っていないことが明らかな場合は削除しておきます。

Link

1
3
1

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
1
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?