Ubuntu 16.04でDockerマシンを使用してリモートDockerホストをプロビジョニングおよび管理する方法

前書き

Docker Machineは、パーソナルコンピューターから複数のDockerホストをリモートで簡単にプロビジョニングおよび管理できるツールです。 そのようなサーバーは一般にDockerizedホストと呼ばれ、当然のことながらDockerコンテナーを実行するために使用できます。

Docker Machineはローカルシステムまたはリモートシステムにインストールできますが、最も一般的なアプローチは、ローカルコンピューター(ネイティブインストールまたは仮想マシン)にインストールし、それを使用してDockerizedリモートサーバーをプロビジョニングすることです。

Docker Machineは、ほとんどのLinuxディストリビューションとMac OS XおよびWindowsにインストールできますが、このチュートリアルでは、Ubuntu 16.04を実行しているローカルマシンにインストールし、Dockerized DigitalOcean Dropletsのプロビジョニングに使用します。

前提条件

このチュートリアルを実行するには、次のものが必要です。

  • DockerがインストールされたUbuntu 16.04を実行しているローカルマシン(https://www.digitalocean.com/community/tutorials/how-to-install-and-use-docker-on-ubuntu-16-04 [インストール方法と使用方法を参照]手順については、Ubuntu 16.04のDocker]をご覧ください)

  • DigitalOcean APIトークン。 お持ちでない場合は、https://www.digitalocean.com/community/tutorials/how-to-use-the-digitalocean-api-v2 [このガイド]を使用して生成してください。 トークンを生成するときは、読み取り/書き込みスコープがあることを確認してください。 これがデフォルトであるため、生成中にオプションを変更しない場合、読み取り/書き込み機能があります。 コマンドラインで使いやすくするために、その記事で与えられているように変数にトークンを割り当ててください。

手順1-ローカルコンピューターにDockerマシンをインストールする

このステップでは、Ubuntu 16.04を実行しているローカルコンピューターにDocker Machineをインストールするプロセスを実行します。

Docker Machineバイナリをダウンロードしてインストールするには、次を入力します。

wget https://github.com/docker/machine/releases/download/v/docker-machine-$(uname -s)-$(uname -m)

ファイルの名前は `+ docker-machine-Linux-x86_64 `でなければなりません。 作業しやすくするために、名前を「 docker-machine」に変更します。

mv docker-machine-Linux-x86_64 docker-machine

実行可能にします。

chmod +x docker-machine

システムコマンドとして利用できるように、それを `+ usr / local / bin +`ディレクトリに移動またはコピーします。

sudo mv docker-machine /usr/local/bin

バージョンを確認すると、バージョンが正しくインストールされていることがわかります。

docker-machine version

出力は次のようになります

Outputdocker-machine version , build 89b8332

ステップ2-追加のDocker Machineスクリプトのインストール

Docker Machine GitHubリポジトリには、 `+ docker `および ` docker-machine +`コマンドの使用を容易にするために設計された3つのbashスクリプトがあります。 コマンド補完とbashプロンプトのカスタマイズを提供します。

このステップでは、これら3つのスクリプトをローカルマシンにインストールします。 それらはダウンロードされ、 `+ / etc / bash_completion.d +`ディレクトリにインストールされます。

最初のスクリプトでは、bashプロンプトからアクティブなマシンを見ることができます。 これは、複数のDocker化されたマシンで作業して切り替えているときに便利です。 スクリプトは「+ docker-machine-prompt.bash」と呼ばれます。 ダウンロードするには、次を入力します。

sudo wget https://raw.githubusercontent.com/docker/machine/master/contrib/completion/bash/docker-machine-prompt.bash -O /etc/bash_completion.d/docker-machine-prompt.bash

上記のファイルのインストールを完了するには、 `+ .bashrc `ファイルの ` PS1 `変数にカスタム値を設定する必要があります。 これを行うには、 ` nano `を使用して開きます( ` PS1 +`はbashコマンドプロンプトの変更に使用される特別なシェル変数です)。

nano ~/.bashrc

そのファイル内には、* PS1 *で始まる3行があります。 これらは次のようになります。

〜/ .bashrc

PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\[email protected]\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ '

PS1='${debian_chroot:+($debian_chroot)}\[email protected]\h:\w\$ '

PS1="\[\e]0;${debian_chroot:+($debian_chroot)}\[email protected]\h: \w\a\]$PS1"

各行について、末尾に `+ $(__ docker_machine_ps1" [%s] ")+`を挿入して、次のようにします。

〜/ .bashrc

PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\[email protected]\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ '

PS1='${debian_chroot:+($debian_chroot)}\[email protected]\h:\w\$ '

PS1="\[\e]0;${debian_chroot:+($debian_chroot)}\[email protected]\h: \w\a\]$PS1"

ファイルを保存して閉じます。

2番目のスクリプトは「+ docker-machine-wrapper.bash 」と呼ばれます。 ` docker-machine`コマンドに` + user`サブコマンドを追加して、Docker Machinesを簡単に切り替えられるようにします。 ダウンロードするには、次を入力します。

sudo wget https://raw.githubusercontent.com/docker/machine/master/contrib/completion/bash/docker-machine-wrapper.bash -O /etc/bash_completion.d/docker-machine-wrapper.bash

3番目のスクリプトは「+ docker-machine.bash」と呼ばれます。 `+ docker-machine`コマンドにbash補完を追加します。 次を使用してダウンロードします。

sudo wget https://raw.githubusercontent.com/docker/machine/master/contrib/completion/bash/docker-machine.bash -O /etc/bash_completion.d/docker-machine.bash

これまでに行った変更を適用するには、端末を閉じてから再度開きます。 SSH経由でマシンにログインしている場合は、セッションを終了して再度ログインします。 `+ docker `および ` docker-machine +`コマンドのコマンド補完が機能するはずです。

手順3-Dockerマシンを使用したDockerizedホストのプロビジョニング

ローカルマシンでDockerとDocker Machineを実行しているので、Docker Machineの `+ docker-machine create +`コマンドを使用して、DigitalOceanアカウントにDockerizedドロップレットをプロビジョニングできるようになりました。 まだ行っていない場合は、次を使用してDigitalOcean APIトークンをbash変数に割り当てます。

export =

変数を永続的にするには、 `+〜/ .bashrc +`ファイルに変数を入れます。 この手順はオプションですが、値をターミナルセッション間で保持したい場合に必要です。

`+ nano +`でそのファイルを開きます:

nano ~/.bashrc

これに似た行をどこかに追加します。

〜/ .bashrc

export =

現在のターミナルセッションで変数をアクティブにするには、次のように入力します。

source ~/.bashrc

`+ docker-machine create +`コマンドを正常に呼び出すには、(少なくとも)ドライバー、APIトークン(またはそれを評価する変数)、およびマシンの一意の名前を指定する必要があります。 最初のマシンを作成するには、次を入力します。

docker-machine create --driver digitalocean --digitalocean-access-token $

マシンの作成中の部分的な出力は次のとおりです。 この出力では、マシンの名前は `+ ubuntu 1604-docker`です:

Output ...
Installing Docker...
Copying certs to the local machine directory...
Copying certs to the remote machine...
Setting Docker configuration on the remote daemon...
Checking connection to Docker...
Docker is up and running!
To see how to connect your Docker Client to the Docker Engine running on this virtual machine, run: docker-machine env ubuntu1604-docker

`+ docker-machine`がリモートでアクセスできるように、新しいホスト用にSSHキーペアが作成されます。 ドロップレットは目的のオペレーティングシステムでプロビジョニングされ、Dockerがシステムにインストールされます。 コマンドが完了すると、Docker Dropletが稼働します。

コマンドラインから新しく作成されたマシンを表示するには、次のように入力します。

docker-machine ls

出力は次のようになります。

OutputNAME               ACTIVE      DRIVER         STATE     URL                         SWARM   DOCKER    ERRORS
ubuntu1604-docker    -        digitalocean   Running   tcp://203.0.113.71:2376            v18.05.0-ce

手順4-Dockerizedホストの作成時にベースOSを指定する

デフォルトでは、Docker Machineを使用してDockerizedホストを作成するときに使用される基本オペレーティングシステムは、_supposed_であり、最新のUbuntu LTSです。 ただし、この公開時点では、Ubuntu 18.04は最新のLTSエディションですが、 `+ docker-machine create `コマンドはベースオペレーティングシステムとしてUbuntu 16.04 LTSを使用しています。 したがって、最近プロビジョニングされたマシンでUbuntu 18.04を実行する必要がある場合は、 `-digitalocean-image `フラグを ` docker-machine create +`コマンドに渡すことにより、目的のバージョンとともにUbuntuを指定する必要があります。

たとえば、Ubuntu 18.04を使用してマシンを作成するには、次のように入力します。

docker-machine create --driver digitalocean  --digitalocean-access-token $

Ubuntuのバージョンに限定されません。 DigitalOceanでサポートされているオペレーティングシステムを使用してマシンを作成できます。 たとえば、Debian 8を使用してマシンを作成するには、次のように入力します。

docker-machine create --driver digitalocean  --digitalocean-access-token $

CentOS 7をベースOSとして使用してDockerizedホストをプロビジョニングするには、次のように、イメージ名として「+ centos-7-0-x86 +」を指定します。

docker-machine create --driver digitalocean  --digitalocean-access-token $ centos7-docker

選択できるのはベースオペレーティングシステムだけではありません。 ドロップレットのサイズを指定することもできます。 デフォルトでは、これは最小のドロップレットであり、1 GBのRAM、単一のCPU、および25 GBのSSDを備えています。

使用するドロップレットのサイズを見つけるには、https://developers.digitalocean.com/documentation/v2/#sizes/ [DigitalOcean API documentation]で対応するスラッグを検索します。

たとえば、2 GBのRAM、2つのCPU、および60 GB SSDを備えたマシンをプロビジョニングするには、スラッグ `+ s-​​2vcpu-2gb +`を使用します。

docker-machine create --driver digitalocean  --digitalocean-access-token $

DigitalOceanドライバーを使用したDockerマシンの作成に固有のすべてのフラグを表示するには、次のように入力します。

docker-machine create --driver digitalocean -h

ステップ5-追加のDockerマシンコマンドの実行

`+ create `サブコマンドを使用してDockerizedホストをプロビジョニングする方法を見てきました。 また、 ` ls `サブコマンドを使用してDocker Machineで使用可能なホストを一覧表示する方法も確認しました。 このステップでは、さらにいくつかの「 docker-machine +」サブコマンドを学習します。

Docker化されたホストに関する詳細情報を取得するには、次のように `+ inspect +`サブコマンドを使用します。

docker-machine inspect

出力には次のような行が含まれている必要があります。 * Image 行は使用されているLinuxディストリビューションのバージョンを示し、 size *行はサイズスラッグを示しています。

Output...
{
   "ConfigVersion": 3,
   "Driver": {
       "IPAddress": "203.0.113.71",
       "MachineName": "ubuntu1604-docker",
       "SSHUser": "root",
       "SSHPort": 22,
       ...
       "Image": "",
       "Size": "",
       ...
   },

---

ホストの接続構成を印刷するには、次のように入力します。

docker-machine config

出力は次のようになります。

Output--tlsverify
--tlscacert="/home/kamit/.docker/machine/certs/ca.pem"
--tlscert="/home/kamit/.docker/machine/certs/cert.pem"
--tlskey="/home/kamit/.docker/machine/certs/key.pem"
-H=tcp://:2376

`+ docker-machine config +`コマンドの出力の最後の行にはホストのIPアドレスが表示されますが、次のように入力してその情報を取得することもできます。

docker-machine ip

リモートホストの電源を切る必要がある場合、 `+ docker-machine`を使用して停止できます:

docker-machine stop

停止していることを確認します。

docker-machine ls

マシンのステータスが変更されました:

OuputNAME                 ACTIVE   DRIVER         STATE     URL                        SWARM   DOCKER    ERRORS
ubuntu1604-docker                  digitalocean

再度開始するには:

docker-machine start

開始されたことを確認します。

docker-machine ls

ホストに対して + STATE s`が + Running`に設定されていることがわかります。

OuputNAME                 ACTIVE   DRIVER         STATE     URL                        SWARM   DOCKER    ERRORS

ubuntu1604-docker         -        digitalocean      tcp://203.0.113.71:2376           v18.05.0-ce

その後、次を使用して削除できます。

docker-machine rm

Dropletは、 `+ docker-machine。+`によって作成されたSSHキーとともに削除されます。これで、Docker化されたホストを一覧表示すると、削除したホストが表示されなくなります。

docker-machine ls

手順6-SSH経由でDockerizedホストでコマンドを実行する

この時点で、マシンに関する情報を取得していますが、それ以上のことができます。 たとえば、ローカルシステムから `+ docker-machine `の ` ssh `サブコマンドを使用して、DockerホストでネイティブLinuxコマンドを実行できます。 このセクションでは、「 docker-machine」を介して「+ ssh」コマンドを実行する方法と、Docker化されたホストへのSSHセッションを開く方法について説明します。

Ubuntuをオペレーティングシステムとしてマシンをプロビジョニングした場合、ローカルシステムから次のコマンドを実行して、Dockerホストのパッケージデータベースを更新します。

docker-machine ssh  apt-get update

以下を使用して利用可能なアップデートを適用することもできます。

docker-machine ssh  apt-get upgrade

リモートDockerホストが使用しているカーネルが不明ですか? 次を入力します。

docker-machine ssh  uname -r

`+ ssh +`サブコマンドを使用してリモートDockerホスト上でコマンドを実行する以外に、このコマンドを使用してマシン自体にログインすることもできます。 入力するのと同じくらい簡単です:

docker-machine ssh

コマンドプロンプトは、リモートホストにログインしているという事実を反映するように変更されます。

リモートホストを終了するには、次のように入力します。

exit

ステップ7-Dockerizedホストのアクティベーション

Dockerホストをアクティブ化すると、ローカルDockerクライアントがそのシステムに接続され、リモートシステムで通常の `+ docker +`コマンドを実行できるようになります。 Dockerホストをアクティブにするには、次のコマンドを入力します。

eval $(docker-machine env )

または、次のコマンドを使用してアクティブ化できます。

docker-machine use

上記のコマンドのいずれかを入力すると、bashプロンプトが変わり、DockerクライアントがリモートDockerホストを指していることを示す必要があります。 この形式を取ります。 ホストの名前はプロンプトの最後に表示されます。

@:~

これで、このコマンドプロンプトで入力した `+ docker`コマンドはすべてリモートホスト上で実行されます。

`+ docker-machine ls +`コマンドが実行される端末でホストがアクティブな場合、* ACTIVE *列の下のアスタリスクはそれがアクティブなものであることを示します。

OutputNAME                ACTIVE          DRIVER         STATE     URL                         SWARM   DOCKER    ERRORS
ubuntu1604-docker           digitalocean   Running   tcp://203.0.113.71:2376             v18.05.0-ce

リモートDockerホストを終了するには、次を入力します。

docker-machine use -u

ローカルシステムのプロンプトに戻ります。

次に、リモートマシンでコンテナを作成します。

ステップ8-リモートDockerizedホストでのDockerコンテナーの作成

これまで、DigitalOceanアカウントにDockerized Dropletをプロビジョニングし、それをアクティブにしました。つまり、Dockerクライアントはそれを指し示しています。 次の論理ステップは、その上でコンテナーをスピンアップすることです。 例として、公式のNginxコンテナを実行してみましょう。

`+ docker-machine use +`を使用してリモートマシンを選択します。

docker-machine use

このコマンドを実行して、そのマシンでNginxコンテナーを実行します。

docker run -d -p 8080:80 --name httpserver nginx

このコマンドでは、デフォルトのNginxページにどこからでもアクセスできるように、Nginxコンテナーのポート「80」をDockerizedホストのポート「8080」にマッピングしています。

コマンドが正常に実行された場合、Webブラウザーで `+ http://:8080 +`を指定することで、デフォルトのNginxページにアクセスできます。

Dockerホストがまだアクティブ化されている間(プロンプトで名前が表示されます)、そのホスト上のイメージを一覧表示できます。

docker images

出力には、使用したばかりのNginxイメージと、以前にダウンロードした他のイメージが含まれている必要があります。

OutputREPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
nginx               latest              ae513a47849c        3 weeks ago         109MB

ホスト上のアクティブまたは実行中のコンテナを一覧表示することもできます。

docker ps

このステップで実行したNginxコンテナーが唯一のアクティブなコンテナーである場合、出力は次のようになります。

OutputCONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                  NAMES
4284f9d25548        nginx               "nginx -g 'daemon of…"   20 minutes ago      Up 20 minutes       0.0.0.0:8080->80/tcp   httpserver

リモートホストのプロンプトを終了するには、入力します。 これにより、ターミナルも閉じられます。

exit

手順9-クラッシュレポートの無効化(オプション)

デフォルトでは、Docker Machineを使用したDockerizedホストのプロビジョニングが失敗するか、Docker Machineがクラッシュするたびに、BugsnagのDockerアカウントにいくつかの診断情報が自動的に送信されます。 これに不安がある場合は、インストール済みの `+ .docker / machine `ディレクトリに ` no-error-report +`という空のファイルを作成して、レポートを無効にすることができます。

ファイルを作成するには、次を入力します。

touch ~/.docker/machine/no-error-report

プロビジョニングが失敗した場合、またはDocker Machineがクラッシュした場合は、エラーメッセージのファイルを確認してください。

結論

これは、Docker Machineをインストールして使用し、1つのローカルシステムから複数のDocker Dropletをリモートでプロビジョニングする方法の概要です。 これで、DigitalOceanアカウントで必要な数のDockerizedホストを迅速にプロビジョニングできるようになります。

Docker Machinesの詳細については、https://docs.docker.com/machine/overview/ [公式ドキュメントページ]をご覧ください。 このチュートリアルでダウンロードした3つのBashスクリプトは、https://github.com/docker/machine/tree/master/contrib/completion/bash [このGitHubページ]でホストされています。

前の投稿:メール・イン・ザ・ボックスのUbuntu 14.04上で自分のメールサーバーを実行する方法
次の投稿:Ubuntu 18.04でマルチノードMySQL Clusterを作成する方法