Alibaba CloudのElastic Compute Service (ECS)上でDockerをセットアップして実行する


このチュートリアルでは、Alibaba Cloud Elastic Compute Service (ECS)インスタンス上でDockerをセットアップして実行する方法を紹介します。

アリババクラウドは日本に2つのデータセンターを有し、世界で60を超えるアベラビリティーゾーンを有するアジア太平洋地域No.1(2019ガートナー)のクラウドインフラ事業者です。
アリババクラウドの詳細は、こちらからご覧ください。
アリババクラウドジャパン公式ページ

Alibaba CloudのElastic Compute Service (ECS)とは?

Alibaba CloudのElastic Compute Service(ECS)は、物理サーバよりもシンプルで効率的な管理が可能な、弾力性のあるクラウドベースのサーバ製品です。インスタンスを作成したり、必要に応じてメモリを追加してスケールアップしたり、接続されたVPCを異なるリージョンに構築したり、アリババクラウドの膨大なクラウド製品やサービスの必須コンポーネントとして利用することができます。

Dockerとは?

Dockerは、コンテナ内でアプリケーションを開発、デプロイ、実行するための管理ツールです。このプロセスはコンテナ化と呼ばれています。

Dockerコンテナは、Dockerイメージを実行することで起動します。Dockerイメージは、コード、ランタイム、必要なライブラリ、環境変数、設定ファイルなど、アプリケーション全体を実行するために必要なすべてを含む実行可能なパッケージです。コンテナはDockerイメージのランタイムインスタンスです。

同じホストマシン上で多くのコンテナを同時に実行することができます。これらのコンテナは、OSのハイパーバイザーの代わりにDockerによって管理されます。コンテナ化とは、アプリケーションが互いに完全に隔離された状態で実行されることを意味します。ただし、実行中のコンテナ間の通信用にポートを設定することもできます。対照的に、仮想マシンはホストマシンからかなりの計算能力を奪い、ほとんどの場合、必要以上に多くのリソースを持っています。

Dockerは軽量で効率的で、最も複雑なアプリケーションを管理することができます。ローカルでDockerコンテナを構築し、クラウドにデプロイし、必要に応じてスケールアップしてどこでも実行することができます。

Dockerはセットアップ、インストール、実行が簡単です。さっそくチェックしてみましょう。

前提条件

Alibaba Cloudアカウントが必要です。まだお持ちでない場合は、無料トライアルのページをご覧ください。

設定

まず、Alibaba Cloud ECSインスタンスをスピンアップしてみましょう。Elastic Computer Serviceの製品ページに移動し、リージョンを選択します。準備ができたら、Create Instanceをクリックします。

基本的な設定を選択します。

OSの種類を選択します。ここではUbuntu 16.04を使用します。

そして、「Next: Networking」をクリックします。

デフォルトのままで 「Next: System Configurations」をクリックしてください。

インスタンスにrootとしてログインするためのパスワードを設定します。その後、「Next: Grouping」をクリックします。

これをそのままにして、「Next: Preview」をクリックしてください。

詳細を確認し、規約に同意し、「Create Instance」をクリックします。

コンソールをクリックしてください。インスタンスが回転しているのがわかります。

インスタンスが起動したら、ターミナルからrootユーザーと先に設定したパスワードでログインすることができます。

これでDockerをインストールする準備が整いました。rootアクセスで作業を続けますが、この時点でUbuntuではあまり権限のないユーザーを設定しておくと良いでしょう。その場合はコマンドをsudoにする必要があります。

また、必要なapt-get update,apt-get upgrade,apt-get dist-upgradeのプロセスを今すぐ行うのも良いアイデアです。

Dockerをインストールするには、まず必要なパッケージを追加し、GPGプライバシーガードキーを追加し、リポジトリをソースに追加し、apt-get updateを実行します。以下のコマンドを実行します。

apt-get install apt-transport-https ca-certificates curl software-properties-common

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | apt-key add -

add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu xenial stable"

apt-get update

今度はDockerをインストールします。

apt-get install docker-ce

Ubuntu上でDockerが動作していることを確認します。

systemctl status docker

これで実行中のDockerアプリケーションができたので、DockerHubのリポジトリからDockerイメージを下に引っ張ってきます。

hello-worldのDockerイメージを実行してみましょう。以下のコマンドを実行します。

docker run hello-world

今までプルダウンしていなかったので、DockerがローカルでDockerイメージを見つけられないことがわかると思いますが、先に進んでDocker公式リポジトリからイメージをプルしてくれます。

プルが完了すると、イメージを実行できるようになります。

DockerHubのウェブサイトで、自由にアクセスでき、Dockerコンテナで実行できるイメージの範囲をチェックしてみてください。

これでDockerのユーザーアカウントを作成して、自分のリポジトリを管理することができるようになりました。
楽しんでくださいね。

まとめ

要約すると、いくつかの前提条件の手順に従って、Alibaba Cloudのアカウントにログインしました。次に、Alibaba CloudのElastic Compute Service(ECS)でUbuntuインスタンスを構築し、ssh経由でログインしました。

その後、いくつかの手順に従ってUbuntuを設定し、Dockerをインストールできるようにしました。Dockerをインストールし、hello-worldイメージを実行しました。

本番環境でコンテナのクラスタ運用を考えている方は、Alibaba Cloud Container Serviceのパッケージを忘れずにチェックしておきましょう。Alibaba Cloud Container Serviceは、ECSインスタンス上でDockerコンテナとKubernetesの両方を簡単にスケーリングして管理するのに役立つ高性能なコンテナオーケストレーションサービスです。Container Serviceは、コンテナクラスタのワンクリックデプロイをサポートしているため、独自のコンテナオーケストレーションソフトウェアをインストールして運用する必要がありません。また、Alibaba Cloudの仮想化、ストレージ、ネットワーク、セキュリティ製品のスイートと統合されています。

Alibaba Cloudの製品およびサービスに関するチュートリアルについては、www.alibabacloud.com/getting-started をご覧ください。

アリババクラウドは日本に2つのデータセンターを有し、世界で60を超えるアベラビリティーゾーンを有するアジア太平洋地域No.1(2019ガートナー)のクラウドインフラ事業者です。
アリババクラウドの詳細は、こちらからご覧ください。
アリババクラウドジャパン公式ページ