このチュートリアルでは、Alibaba Cloudのコンテナサービスを使ってDockerコンテナクラスタを作成する方法を紹介します。
本ブログは英語版からの翻訳です。オリジナルはこちらからご確認いただけます。一部機械翻訳を使用しております。翻訳の間違いがありましたら、ご指摘いただけると幸いです。
#アリババクラウドのコンテナサービスとは?
Alibaba Cloud's Container Serviceは、スケーラブルで高性能なコンテナ管理サービスで、Docker SwarmまたはKubernetesのいずれかを使用してコンテナ化されたアプリケーションのライフサイクルをオーケストレーションして管理することができます。
Alibaba Cloudのコンテナサービスは、継続的インテグレーションを含む複数のアプリケーションリリース方法を提供し、マイクロサービスアーキテクチャもサポートしています。Alibaba Cloudの仮想化、ストレージ、ネットワーク、セキュリティサービスと統合されたコンテナクラスタのUI設定を簡素化することで、Alibaba Cloudのコンテナサービスは、コンテナ化されたアプリケーション環境の実行、管理、監視に最適なクラウド環境となっています。
#Docker Swarmとは?
Dockerはオープンソースの仮想化管理ツールで、コンテナ内でアプリケーションやシステムを開発、デプロイ、管理、監視することができます。このプロセスはコンテナ化と呼ばれています。Docker Swarmは、複数のスケーラブルなDockerコンテナ上で動作するシステムや環境のためのクラスタリング、スケジューリング、オーケストレーションツールです。
Dockerコンテナは、コード、ランタイム、ライブラリ、環境変数、設定ファイルなど、アプリケーション全体の実行に必要なすべてを含む実行可能パッケージであるDockerイメージを実行することで起動します。コンテナはDockerイメージのランタイムインスタンスです。
同じインスタンス上で複数のコンテナを同時に実行したり、インスタンスのクラスタスウォームを実行したりすることができ、コンテナはオペレーティングシステムのハイパーバイザーの代わりにDockerによって管理されます。これにより、1つ以上のクラスタノードに問題が発生した場合の冗長性とフェイルオーバーを提供します。
Dockerは軽量で効率的で、複数のアプリケーションで構築された最も複雑なシステムを管理することができます。ローカルでDockerコンテナを構築し、クラウドにデプロイして、必要な場所でスケールアップ、スケールダウンして実行することができます。
Dockerは、単一のECSインスタンス上で簡単にセットアップ、インストール、実行できます。業界レベルのアプリケーションやシステムを実行する大規模なコンテナ化環境には、信頼性と拡張性に優れたオーケストレーションと監視システムが必要です。Alibaba Cloudのコンテナサービスは、システム管理者やDevOpsチームに、大規模なコンテナ化環境を管理するために必要なクラスタ化アーキテクチャを提供します。
#クラスタを作成する必要がある理由
Alibaba Cloudのコンテナサービスで実行中のDockerコンテナのスイートをインストールする前に、コンテナ化されたシステムを実装するためのAlibaba Cloud Container Service Docker Swarmクラスタを準備して利用できるようにしておく必要があります。
このチュートリアルでは、そのようなクラスタを構築するための予備的なステップを説明します。次のチュートリアルでは、Alibaba Cloudのコンテナサービスを使ってDocker SwarmクラスタにDockerイメージを実装する方法を紹介します。
#前提条件
Alibaba Cloudアカウントが必要です。アカウントをお持ちでない場合は、無料トライアルのページにアクセスして、Alibaba Cloud New User Free Trialで300ドル相当のAlibaba Cloud製品にアクセスして遊んでみましょう。
それでは、始めましょう。
#クラスタの作成
まず、商品ページに向かい、コンテナサービスをクリックします。
Container Serviceコンソールページに到着します。
Create Clusterをクリックする前に、Container Service Swarmオプションが選択されていることを確認してください。
クラスタにユニークな名前をつけ、RegionとZoneを選択してください。
クラスタのVPCの詳細とIPの初期CIDRブロック範囲を確認します。
既存のECSインスタンスをクラスタに追加することも、新しいインスタンスを作成することもできます。このチュートリアルでは、クラスタ用に4つの小さなインスタンスを作成してみましょう。
必要に応じてデータストレージを追加してください - しかし、各ECSインスタンスには最低限のストレージが付属しています。
OSはUbuntuかCentosのどちらかを選択できます。
安全にアクセスするためのキーペアを設定したり、必要に応じてインスタンスにアクセスするためのルートパスワードを設定したりすることができます。
オプションのチェックを外してパブリックIPアドレス(EIP)を設定したままにしておき、インスタンスにもクラウド監視プラグインをインストールします。
クラスタにはServer Load Balancerが自動的に作成されるように設定されています。
必要に応じて、クラスタ上で事前に設定した Relation Database Service (RDS) インスタンスを選択することができ、クラスタ作成プロセスでは、Virtual Private Cloud (VPC) 上の関連するプロトコルタイプのセキュリティグループが設定されます。
設定の詳細に問題がなければ、ページの上部にある「作成」をクリックします。
作成をクリックすると、クラスタ構成の詳細をまとめたページが表示され、確認を求められます。
クラスタ構成が必要に応じて適切であることを確認したら、[OK]をクリックします。
リクエストが送信されました。クラスタの作成中にレポートログが表示されます。
必要なサービスがまだ起動していないという警告に気づいた場合は、先に進みましょう。
クラスタが作成されると、画面上に確認画面が表示されます。
クラスタ一覧に戻るをクリックします。
クラスタリストには、利用可能なクラスタと実行中のクラスタが表示されます。
ここで、Overviewをクリックすると、クラスタのグラフィカルな表示が表示されます。
Nodes をクリックすると、クラスタを構成するパブリックおよびプライベートIPアドレス、ステータス、その他の設定情報を含む ECS インスタンスのリストが表示されます。
この例のアプリケーション、サービス、コンテナのセクションには、デフォルトのビルドシステムのアプリケーションとサービス、インスタンスごとに自動的に含まれる7つのコンテナの情報がリストアップされています。
これで、先ほど作成したAlibaba Cloud Container Serviceクラスタ上にDocker Swarmコンテナ化システムをセットアップする準備が整いました。
#まとめ
最初に、Alibaba Cloud Container Serviceのアプリケーション環境を動かすためのクラスタを構築するとお伝えしましたが、今回のチュートリアルではDocker Swarmクラスタになります。今後のチュートリアルでは、コンテナサービスのKubernetesオプション用のクラスタも構築する予定です。
続いて、Alibaba Cloudのコンテナサービス製品について簡単に説明し、その高性能、スケーラビリティ、使いやすいコンソールが、コンテナ化されたアプリケーション環境をAlibaba Cloudの膨大な製品やサービスと統合するのに最適な方法であることを説明しました。
チュートリアルの最初の部分では、Docker Swarmクラスタを構築して、実行中のアプリケーションを構成するDockerコンテナを選択してDocker Swarmアプリケーションを構築することを説明しました。
最後に、Alibaba Cloud Container ServiceのDocker Swarmクラスタを構築するプロセスをステップバイステップで説明し、設定オプションを説明しながら進めていきます。
次のチュートリアルでは、Alibaba Cloudのコンテナサービスを使ってDocker Swarmクラスタ上に実行中のアプリケーション環境を構築する方法を紹介します。
アリババクラウドは日本に2つのデータセンターを有し、世界で60を超えるアベラビリティーゾーンを有するアジア太平洋地域No.1(2019ガートナー)のクラウドインフラ事業者です。
アリババクラウドの詳細は、こちらからご覧ください。
アリババクラウドジャパン公式ページ