こんにちは。
株式会社クラスアクト インフラストラクチャ事業部の大塚です。
今回はAWSのコンテナサービスであるECSを見よう見まねで使用してみたいと思います。
具体的にはECSでnginxコンテナをデプロイして、Webブラウザでアクセスしてみたいと思います。
用語
AWS ECS
Elastic Container Serviceの略。
説明は公式に委ねますが、AWS側でデプロイとかスケーリングとか色々マネージングしてくれる便利なやつ位のイメージしかありません。今後頭の中のイメージを具体化していけば良いと思っています。
コンテナ化されたアプリケーションのデプロイ、管理、スケーリングを容易にするフルマネージドコンテナオーケストレーションサービスです。アプリケーションと必要なリソースを記述するだけで、Amazon ECS が柔軟なコンピューティングオプションで、アプリケーションを起動、モニタリング、スケーリングし、アプリケーションが必要とする他の AWS サポートサービスと自動的に統合します。カスタムのスケーリングルールやキャパシティルールの作成などのシステムオペレーションを実行し、アプリケーションログやテレメトリからデータを確認し、クエリします。
AWS Fargate
今回のnginxコンテナデプロイにはFargateと呼ばれるサーバレスコンピューティング技術を使っています。
これも詳細は公式サイトに委ねます。コンテナ向けのLambdaくらいのイメージしか今はありません。
AWS Fargate は、サーバーレスで従量制料金のコンピューティングエンジンであり、サーバーを管理することなくアプリケーションの構築に集中することができます。AWS Fargate は、Amazon Elastic Container Service (Amazon ECS) と Amazon Elastic Kubernetes Service (Amazon EKS) の両方との互換性を備えています。 OCI 準拠のコンテナイメージを選択し、メモリとコンピューティングリソースを定義して、サーバーレスコンピューティングでコンテナーを実行します。複数の CPU アーキテクチャとオペレーティングシステムがサポートされているため、さまざまなアプリケーションでメリットを享受できます。
Amazon ECR Public Gallery
コンテナと言えばDockerですが、Dockerでコンテナをデプロイする時、コンテナイメージはDocker Hubからpullされます。
AWS ECSの場合、Docker Hubの代わりにこのECR Public Galleryを使うッぽいです。
恐らくDocker Hubと連携も普通に出来るんだと思いますが、今回はこっちから引っ張ってきました。
構築時参考にしているサイト
UIが今のものと違うッぽいですが参考になりました。
ありがとうございます。
構築
task作成
ECSのサイトを開く。左のタスク定義を押下する。
新しいタスク定義の作成を押下する。
今回は以下のタスクを作成しました。
- タスク名をtest-task。
- コンテナをFargateで作成。
- イメージURIはECR Public Galleryから取得。
正常に作成されると以下の様に表示されます。
クラスタ作成
クラスターを押下後、クラスターの作成を押下する
今回はtest-clusterというクラスタ名で作成しています。
正常に作成されると以下の様に表示されます。
クラスタにタスクを実行させコンテナをデプロイし、Webブラウジングする
上記の画面のクラスタ名がリンクになっている為、押下する。
タスクタブをアクティブにして、新しいタスクの実行を押下する。
以下の様に設定を入れました。
- デプロイ設定でタスクを選択。ファミリー欄で作成したタスクを選択。
- セキュリティグループで設定を変更。デフォルトのままだとhttp接続するために修正する必要が出てきたので、初めから接続出来るように変更してます。
プロビジョニングが走ります。
暫くすると実行中になるはずです。タスク名がリンクになっていると思うので、押下します。
パブリックIPが表示されていると思います。これがコンテナに外部から接続する為のIPアドレスになります。
今回はhttp://18.183.22.85になります。
接続出来ました。とりあえず動かせたので一安心。コンテナは割と好きで得意な技術なのですが少々癖があるなと思いました。