Slide 1

Slide 1 text

クラウド開発室 横田真俊(@Wslash) さくらインターネット株式会社 初心者向けDockerハンズオン Dockerを触ってみよう! 2016/08/10

Slide 2

Slide 2 text

全体の流れ •「さくらのクラウド」のご紹介 •「さくらのクラウド」を選ぶポイント •「さくらのクラウド」のアーキテクチャ •最近の主な機能アップデート •新機能リリース情報 •デモ 2

Slide 3

Slide 3 text

自己紹介 氏名 横田真俊(@Wslash) 「さくらのインターネット」の エバンジェリスト 兼 さくらのクラウド企画担当です。 年に50回ほどのセミナーやハンズオンなどを担当しています。 左のアイコンで、ツイッターをやっていますので お気軽にお声がけください 3

Slide 4

Slide 4 text

昔こんな本を書いていました Amazon EC2/S3 入門 今は「さくらのクラウド」企画担当 ですが、昔はこんな本を書いていました。 4

Slide 5

Slide 5 text

他にもこんな本を書いております ツイッターやFacebookなど ソーシャルメディアの本 を5冊ほど書いてます。 5

Slide 6

Slide 6 text

他にもこんな本を書いております インフラエンジニア向けの 本も書きました。 6

Slide 7

Slide 7 text

Dockerに触れることで コンテナがどのようなものか 体験していただきます 7

Slide 8

Slide 8 text

Dockerコンテナの 何がすごいのか? 8

Slide 9

Slide 9 text

今までの仮想化(1) 「ホストOS仮想型」 9 ホストOSの上で「仮想化ソフト」を動かすタイプ ホストOSとアプリを共存できるのでPCからの個人利用の形 で多いが、ホストの負荷が大きい ホスト形仮想化ソフト (VirtualBOXなど) OS (1) OS(2) OS(3) アプリ アプリ アプリ ホストOS(Windows/Linuxなど) アプリ

Slide 10

Slide 10 text

今までの仮想化(2) 「ハイパーバイザー型」 10 ホストOSの代わりに「ハイパーバイザー」が仮想サーバを 制御する。ホストサーバ全体を仮想化で利用するため、ホス トOSを経由しないためホストOS型よりレスポンスが良い ハイパーバイザー (VMWareなど) OS (1) OS(2) OS(3) アプリ アプリ アプリ

Slide 11

Slide 11 text

「コンテナ」 11 OSの代わりに各コンテナがアプリを稼動させます。今まで より一番ホストマシンの処理負荷が低い コンテナ管理ソフトウェア (Dockerなど) コンテナ(1) コンテナ(2) コンテナ(3) アプリ アプリ アプリ ホストOS(Linux) アプリ

Slide 12

Slide 12 text

よく言われるDocker(コンテナ)のメリット •処理速度が速い → OSやハードウェアを仮想化していないため オーバーヘッドが少なく処理能力が高い •メモリやディスクの消費量をおさえられる → それぞれにカーネルを持たないため メモリ/ディスクの消費量をおさえられる。 •ポータビリティ → 環境を意識せず使える 12

Slide 13

Slide 13 text

13 何がうれしいのか?

Slide 14

Slide 14 text

Docker(メリット) ■検証・使い捨て環境がすぐに使える → 「低コスト」かつ「コマンド1発」で利用できる。 ■環境の統一化 → 開発・運用・ステージングと色々な「環境」を 用意せずにコンテナに統一できる。 ■クラウド時代のバズワードが手軽に実現 → イミュータブル、オートスケーリング etc… 14

Slide 15

Slide 15 text

コントロールパネルに ログインしてみよう 15

Slide 16

Slide 16 text

「コントロールパネル」にログイン 16 「コントロールパネル」にログインするには、Webサイトの上部にある 「コントロールパネルログイン」をクリックしてください

Slide 17

Slide 17 text

「コントロールパネル」にログイン 17 「コントロールパネル」にログインしたら「さくらのクラウドユーザ」 としてログインの箇所にある「ユーザコード」「会員ID」 「パスワード」を入力してください

Slide 18

Slide 18 text

ログイン後の画面 18 無事にログインできたら、このような画面が表示されますので 「さくらのクラウド(IaaS)」をクリックしてください

Slide 19

Slide 19 text

ログイン後の画面 19 さくらのクラウド(IaaS) をクリックすると このような画面が表示されます

Slide 20

Slide 20 text

サーバを作成してみよう 20

Slide 21

Slide 21 text

まずは一番小さいサーバを作成してみよう 21 ・まずは、CPU 1ギガ、メモリ 1GB、ディスク SSD 20GB、NIC 1のもので OSはCent OS 7.2の物を作成してみましょう

Slide 22

Slide 22 text

サーバを作成する 22 ・メインメニューより「サーバ」をクリック ・その後「追加」をクリックすると「サーバ作成画面」に移動します

Slide 23

Slide 23 text

サーバ作成画面(1) 23 まず「ホスト名」を入力し、次にサーバプランを選択します。今回はホスト 名は適当に入力し、サーバプランは「1GB/1仮想コア」を選択します。

Slide 24

Slide 24 text

サーバ作成画面(2) 24 ボタンにないプランの場合は「全てのアイテムから選択」を選択すると アイテム一覧が表示され、そこから選択できます

Slide 25

Slide 25 text

サーバ作成画面(3) 25 次に「ディスクプラン」を選択します。今回は「20GB SSDプラン」を選択 します。上記のプランにない物を利用する場合は、サーバと同じように「全 てのアイテムから選択」を選択してください。

Slide 26

Slide 26 text

サーバ作成画面(4) 26 ディスクイメージを選択します、利用したい「OS」を選択してください。 今回は「CentOS 7.2」を利用します。

Slide 27

Slide 27 text

サーバ作成画面(5) 27 接続のネットワークに「インターネット」を選択し「管理ユーザのパスワー ド」でrootのパスワードを入力します。

Slide 28

Slide 28 text

シンプルモードを解除する 28 全ての入力項目を入力し終わった後「作成」をクリックします

Slide 29

Slide 29 text

29 「操作確認」のダイアログが表示されます。問題が無ければ「作成」をク リックします。

Slide 30

Slide 30 text

30 「作成」をクリックすると上記のダイアログが出てきます。 ステータスが全て成功になるとサーバが作成されます。

Slide 31

Slide 31 text

31 サーバの作成が完了すると、画面の右下にダイアログが表示されます。これ をクリックしてください。

Slide 32

Slide 32 text

32 ダイアログをクリックすると、サーバ情報が表示されます。

Slide 33

Slide 33 text

リモートスクリーンについて 33

Slide 34

Slide 34 text

「リモートスクリーン」 34 ブラウザ内でサーバの操作ができます。作成したサーバの 「コンソール」をクリックしてください。

Slide 35

Slide 35 text

文字入力の方法 35 画面中央をクリックすると、文字入力ができるようになりま す。rootと先ほど入力したパスワードを入れてください

Slide 36

Slide 36 text

「リモートスクリーン」 36 「ペースト」を選択すると、文字列のペーストも可能です

Slide 37

Slide 37 text

37 IPアドレスでSSH接続できるので わかる方はそれで接続してください

Slide 38

Slide 38 text

Dockerをインストールする 38

Slide 39

Slide 39 text

Dockerをインストールするサーバについて 39 今回はCentOS 7系でインストールします 今日の資料は別途、公開いたします 2万円クーポンを配るのでそれで復習できます

Slide 40

Slide 40 text

サーバにDockerをインストールする 40 「curl -sSL https://get.docker.com/ | sh」とコマンドを入れるとDocker のインストールがはじまります。 curl -sSL https://get.docker.com/ | sh

Slide 41

Slide 41 text

Dockerを開始する 41 「systemctl start docker」とコマンドを入れるとDockerが動きます systemctl start docker

Slide 42

Slide 42 text

Dockerがインストールされているか確認 42 「docker version」と入力してDockerのバージョンが表示されれば、 Dockerが正常にインストールされています。 docker version

Slide 43

Slide 43 text

43 コンテナを起動する「docker run」

Slide 44

Slide 44 text

docker run ■docker run コマンド → 指定したイメージのコンテナを起動する ■構文 → docker run イメージ [オプション][コマンド][引数] ■オプション → -d バックグランドで実行 → -i コンテナの標準入力を開く → -t ttyを確保する → -p ポートフォワード 44

Slide 45

Slide 45 text

Hello World 45 ちゃんとDockerが動くか「hello world」を動かしてみたいと思います。 上記のコマンドを入力してください。 docker run hello-world

Slide 46

Slide 46 text

docker run hello-worldの結果 46 「hello world」の入力が終わると「docker run –it ubuntu bash」を試し てみろ、と言われているので、これを入力してみましょう。

Slide 47

Slide 47 text

ubuntuを入れてみる 47 Dockerの上でUbuntuを入れて、コマンド入力ができるようにしてみる。 「-it」で、コンテナの中で入力できるようになる。 docker run -it ubuntu bash

Slide 48

Slide 48 text

Dockerを利用することでCentOS上でubuntuを 利用することができます。 ただし、このubuntuには、ほとんどコマンドが 入っていません。 例えば「curl ifconfig.me/ip」を叩くと、なに も表示されないと表示されます。 48

Slide 49

Slide 49 text

49

Slide 50

Slide 50 text

起動したubuntuにcurlを利用できるようにする 50 「apt-get update」を叩いた後「apt-get install curl」で「curl」をインス トールしてください。インストール中、色々と聞かれますがとりあえずyを 押して下さい。 apt-get update apt-get install curl (1) (2)

Slide 51

Slide 51 text

Curlがインストールされていることの確認 51 「curl ifconfig.me/ip」でIPを表示してみる curl ifconfig.me/ip

Slide 52

Slide 52 text

作成したコンテナから出る 52 「exit」をコマンドを叩くとコンテナから出て、このコンテナが止る。 コンテナが止ると今までやった作業(apt-getとか)は保存されない。 exit

Slide 53

Slide 53 text

再度、コンテナを動かすと… 53 再度コンテナを起動して「curl ifconfig.me/ip」を入力してください。これ を入力しても、先ほどのように実行されないはずです。 docker run -it ubuntu bash curl ifconfig.me/ip (1) (2)

Slide 54

Slide 54 text

コンテナについて •exitするだけで、今までの動作が消えてしまう ので、このままだと使えないです。 •次はバックグランドでDockerのコンテナを利 用する方法について解説します。 54

Slide 55

Slide 55 text

55 バッググランドでコンテナを動かす

Slide 56

Slide 56 text

今の時刻を毎秒表示するコンテナを起動する 56 上記のコンテナを起動すると、時刻を1秒ごとに表示するコンテナが表示さ れる。しばらく動かしてみて「ctrl + C」で止めてください。 docker run jpetazzo/clock

Slide 57

Slide 57 text

さきほどのコンテナをバックグランドで動かす 57 コンテナをバックグランドで動かすにはrunコマンドに「-d」をつける。 上記のコマンドを入力すると、先ほどのように時刻は表示されずバックグラ ンドで動いており、ログは記録されている。 docker run -d jpetazzo/clock

Slide 58

Slide 58 text

58 docker psでコンテナを確認する

Slide 59

Slide 59 text

docker ps ■docker ps コマンド → コンテナIDを確認するためコマンド。これでわか るものは ・コンテナのID ・コンテナがどのイメージから作られたのか? ・コンテナが動いてどのぐらい経過したのか? ■オプション → -l 直近(latest)のコンテナの情報を表示 → -q コンテナのショートIDのみ表示 → -a 停止しているコンテナも含め全て(all)表示 59

Slide 60

Slide 60 text

docker psでコンテナの確認 60 docker psを入力すると、現在動いているコンテナの情報が見られる docker ps

Slide 61

Slide 61 text

docker psのオプション 61 「docker ps –l」で直近に操作したコンテナを表示し「docker ps -q」でコ ンテナのショートIDが表示される。 docker ps -l docker ps -q (1) (2)

Slide 62

Slide 62 text

62 docker logsでコンテナ のログを確認する

Slide 63

Slide 63 text

docker logs ■docker logs コマンド → コンテナの標準出力の内容をコンテナ外から 確認する ■オプション → -tail ログの最後数行が見られるようになる → -follow リアルタイムでログが確認できる。 63

Slide 64

Slide 64 text

docker logs 64 「docker logs(コンテナのID)」を入力すると、コンテナの標準出力が見 られる。先ほどバックグランドで動かした「 jpetazzo/clock 」のコンテナ IDを入力してみましょう。 docker logs (コンテナのID)

Slide 65

Slide 65 text

docker logsのオプション 65 「-- tail」オプションを使うことで、ログの最後数行が見られるようになる。 例えば、(1)のコマンドはログの最後3行を出すコマンドとなる。 docker logs --tail 3 (コンテナのID)

Slide 66

Slide 66 text

66 docker logs --tail 1 --follow (コンテナのID) Unixコマンドのtail -fのようにfollowオプションをつけることでリアルタイ ムでログを確認することができる。上記のコマンドを入力するとリアルタイ ムでログが表示される。止めるには「Ctrl + C」で

Slide 67

Slide 67 text

67 docker kill、docker stopで コンテナを止める

Slide 68

Slide 68 text

コンテナの停止 68 「-d」で動作したコンテナを止めるにはkillかstopを使う。今回はkillコマン ドで、先ほどのコンテナを止めてください。 docker kill (コンテナのID) docker stop (コンテナのID) (1) (2)

Slide 69

Slide 69 text

停止したコンテナを確認する 69 「docker ps」で先ほど止めたコンテナのIDが無いことを確認してください 「docker ps –a」で止めたコンテナも確認できます。 docker ps docker ps -a (1) (2)

Slide 70

Slide 70 text

Docker上でGhostを インストールする 70

Slide 71

Slide 71 text

71 これだけではつまらないので アプリを入れてみましょう

Slide 72

Slide 72 text

Ghostとは? 72 「Ghost」は最近、人気が出ているNode.js製の軽量ブログエンジンです。 今回はDockerを利用して、コマンド1発でインストールします。

Slide 73

Slide 73 text

通常でGhostをインストールするのに必要なもの 73 • Node.jsとnpm • ApacheとかのWebサーバ • その他、色々 「Ghost」をインストールして利用するには上記のような物を色々とインス トールする必要があり面倒です。

Slide 74

Slide 74 text

DockerからGhostを入れる 74 Ghostを80番ポートで利用できるようにします。元々Ghostは2368番ポート で動いているので80番ポートとマッピングさせます。 docker run -p 80:2368 -d ghost

Slide 75

Slide 75 text

インストールが終わったらIPアドレスをいれる 75 インストールが終わったら「(IPアドレス)」をブラウザで入力してください。 上記のような「画面」が表示されます。「(IPアドレス)/admin」でGhostの セットができます。

Slide 76

Slide 76 text

docker psでコンテナIDを調べる 76 起動を確認したら、このコンテナを止めてみましょう。コンテナの止め方は 「docker stop (コンテナのID)」で止りますので「docker ps」でコンテナ IDを調べます。 docker ps

Slide 77

Slide 77 text

docker psでコンテナIDを調べる 77 「docker ps」を入力して「CONTANER ID」を確認する。

Slide 78

Slide 78 text

docker psでコンテナIDを調べる 78 「docker stop (コンテナのID)」を入力すると、ghostのコンテナが止りま す。(先ほどの例だと07a4e04f6418となります。) docker stop (CONTANER ID)

Slide 79

Slide 79 text

Docker上でWordPressを インストールする 79

Slide 80

Slide 80 text

80 WordPressとMy SQLのコンテナを つなぎ、WordPressを動かす

Slide 81

Slide 81 text

Wordpressをインストールしてみる 81 上記のコマンドを入力すると、色々とダウンロードがはじまる。 docker run wordpress

Slide 82

Slide 82 text

Wordpressをインストールしてみる 82 エラーが出てWordPressが起動できない、どうやらMySQLが必要な様子。 というわけで、MySQLのコンテナを持ってくる。

Slide 83

Slide 83 text

MySQLイメージのダウンロード 83 「docker pull [イメージ名]」でイメージのダウンロードがはじまります。 ちなみに「docker run [イメージ名]」をした時にローカルにコンテナイメー ジがないと自動的にダウンロードされます docker pull mysql

Slide 84

Slide 84 text

MySQLの設定 84 わかりやすいように –eを利用することでMySQLのパスワードの設定が可能 となります。(パスワード)には、任意のパスワードを入れてください docker run --name mysql -e MYSQL_ROOT_PASSWORD=(パスワード) -d mysql

Slide 85

Slide 85 text

Wordpressの立ち上げ 85 上記のコマンドを入力するとWordPressが立ち上がります。「-- link」は、- -link <連携したいコンテナ名>:<エイリアス名>オプションで新しいコンテ ナを起動すると,そのコンテナ内で連携したいコンテナのポート番号やIPを 環境変数として利用できるという機能です docker run --name wordpress --link mysql:mysql -p 80:80 wordpress

Slide 86

Slide 86 text

86 インストールに成功するとこんな画面が出てきます。

Slide 87

Slide 87 text

ブラウザでIPアドレスにアクセス 87

Slide 88

Slide 88 text

88 「-d」を指定していないので「ctrl + c」を入力すると、このコンテナ自体 も停止してしまいます。 それでは、次はバッグランドでWordPressを起動してみましょう。 ただし、同じ名前のコンテナ(--name以下)は作れないので、名前を変えて みましょう。

Slide 89

Slide 89 text

Wordpressの立ち上げ 89 上記のコマンドを入力するとWordPressが起動します。起動するのを確認し たら、docker killで落としてみましょう。 docker run --name wordpress2 -d --link mysql:mysql -p 80:80 wordpress

Slide 90

Slide 90 text

Dockerfileを利用して、 Dockerイメージを作る 90

Slide 91

Slide 91 text

Docker コンテナとDocker イメージの違い ・「Docker run」をコマンドを叩くとDocker イメージからDocker コンテナが作られる ・Dockerイメージは読み込みのみ可能(read- only)。変更はできない。 ・Dockerコンテナは、読み書きができるファイ ルシステム 91

Slide 92

Slide 92 text

新しいイメージを作るには 92 本日はDocker fileからDockerイメージを作る「docker build」を試します ・docker commit → コンテナからDocker イメージを作る。 ・docker build → Docker fileからDockerイメージを作る。 ・docker import → Base imageからDockerイメージをつくる。

Slide 93

Slide 93 text

自分が使用したイメージの表示 93 このコマンドを入力すると、過去に利用したDockerイメージが表示されます docker images

Slide 94

Slide 94 text

94 Dockerfileを利用して、 Dockerイメージを作る。

Slide 95

Slide 95 text

Dockerfile? ・DockerfileはDockerイメージを作るためのレ シピのようなものです。 ・ Dockerfileは作成するDockerイメージの内容 をテキスト形式で記述します。 ・作成したテキストファイルはdocker buildコ マンドで読み込んでDockerイメージの作成を実 行します。 95

Slide 96

Slide 96 text

Dockerfileを書いてみる 96 Dockerfileをvimで書いてみます「myimages」というフォルダを作ってvim でDockerfileという名前のファイルを作製します。 mkdir myimage cd myimage (1) (2) vim Dockerfile (2)

Slide 97

Slide 97 text

簡単なDockerfileを作る 97 「a」を押して入力モード上記の三行を入力する。入力が終わったら、Escで コマンドモードに戻った後「:wq」で保存する。 FROM ubuntu RUN apt-get update RUN apt-get install -y wget

Slide 98

Slide 98 text

docker build ■docker build コマンド → DockerfileからDockerイメージを作る ■構文 docker build –t :<タ グ名> 98

Slide 99

Slide 99 text

docker build 99 dockerビルドコマンドを入力して、Dockerイメージを作成してください。 docker build -t myimage .

Slide 100

Slide 100 text

100 Successfully built <イメージID>が出れば、イメージの作成成功

Slide 101

Slide 101 text

docker build 101 作成したイメージは上記のコマンドから実行できます。 docker run -it myimage bash

Slide 102

Slide 102 text

102 Docker Compose

Slide 103

Slide 103 text

Docker Composeとは? 103 Docker Composeは、複数のコンテナか ら構成するサービスを従来よりも簡単に 構築できるツールです。 従来はコンテナを作成するには、いちい ち「docker run」しなければならなかっ たのが、コマンド1発で複数のコンテナ を利用したサービスを構築できます。

Slide 104

Slide 104 text

104 Docker Composeを利用して Rocket.Chatの環境を構築する

Slide 105

Slide 105 text

Docker composeのバイナリをセットする。 105 上記のコマンドを入力して、Docker Composeのバイナリをセットする curl -L https://github.com/docker/compose/releas es/download/1.8.0/docker-compose- `uname -s`-`uname -m` > /usr/local/bin/docker-compose chmod +x /usr/local/bin/docker-compose curl -L https://github.com/docker/compose/releases/download/1.8.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose chmod +x /usr/local/bin/docker-compose curl -L https://github.com/docker/compose/releases/download/1.8.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose chmod +x /usr/local/bin/docker-compose

Slide 106

Slide 106 text

Docker composeがインストールされたか確認 106 「docker-compose version」を入力すると、Docker composeのバージョ ンが表示される、正しくインストールされれば、このコマンドでバージョン 情報が表示される。 docker-compose version

Slide 107

Slide 107 text

Docker-compose.yamlの作成 107 本来であれば、作業用のディレクトリの中に「docker-compose.yaml」を用 意する必要があるのですが、今回は事前に私の方で作成したので、そちらをク ローンしてください。クローンが終わったら「rocketchat」に移動します。 git clone https://github.com/zembutsu/sakura-cloud- hands-on.git cd sakura-cloud-hands-on/rocketchat

Slide 108

Slide 108 text

イメージを取得する 108 先ほど作成したディレクトリ「rocketchat」の中で「docker-compose pull」を入力。Rocket.Chatに必要なイメージをダウンロードします。 docker-compose pull

Slide 109

Slide 109 text

イメージを取得する 109 エラーが出ていなければ「docker images」を入力して「mongo」と 「rocketchat/rocket.chat」と「rocketchat/hubot-rocketchat」のイメー ジを取得できているか確認をする。 docker images

Slide 110

Slide 110 text

110 エラーが出ていなければ「docker images」を入力して「mongo」と 「rocketchat/rocket.chat」と「rocketchat/hubot-rocketchat」のイメー ジを取得できているか確認をする。 # docker images REPOSITORY TAG IMAGE ID CREATED SIZE mongo latest 7f09d45df511 5 days ago 336.1 MB rocketchat/rocket.chat latest 30826dfbbfa6 2 weeks ago 332.4 MB rocketchat/hubot-rocketchat latest a727f5c88c43 5 weeks ago 800.5 MB

Slide 111

Slide 111 text

Composeを使って複数のコンテナを立ち上げる 111 イメージを取得できていれば「docker-compose up -d」を入力して Rocket.chat起動に必要な複数のコンテナを立ち上げます。 docker-compose up -d

Slide 112

Slide 112 text

「docker ps」を入力して動作を確認する 112 「docker-compose up -d」でコンテナを立ち上げた後「docker ps」で、 正常に動作しているか確認する。 docker ps

Slide 113

Slide 113 text

ブラウザで「IPアドレス」を入力する 113 正常に動作していれば、ブラウザに http://サーバのIPアドレス:3000/ を入 力すれば、Rocket.Chat ログイン画面が表示されます。「新しいアカウント を登録」をクリック後、名前、メールアドレス、パスワードを入力します。

Slide 114

Slide 114 text

まとめ 114

Slide 115

Slide 115 text

まとめ Docker の基本コマンドを学びました DockerとDocker Composeを利用すると、 すぐに検証環境が利用できて便利 115

Slide 116

Slide 116 text

116 ご静聴ありがとうございました。 「さくらのクラウド 2万円クーポン」を配布いたします。 今日の復習にご利用ください

Slide 117

Slide 117 text

117 ご清聴ありがとうございました http://cloud.sakura.ad.jp