SlideShare a Scribd company logo
Copyright © 2021 Toranoana Inc. All Rights Reserved.
Webアプリケーション開発者のための
Docker, Docker Composeハンズオン
虎の穴ラボ はっとり
1
Copyright © 2021 Toranoana Inc. All Rights Reserved.
2
目次
● はじめに・事前準備
● Dockerについて(5分)
● Dockerを使ってみる(15分)
○ HelloWorld
○ 仕組み説明
○ Nginx建ててみるDocker編
● Docker Composeを使ってみる(15分)
○ Nginx建ててみるDocker Compose編
○ MySQLを建ててみる
● Railsアプリケーション構築(15分)
Copyright © 2021 Toranoana Inc. All Rights Reserved.
3
はじめに
● このハンズオンはDockerを体験することを重視しているので解説は
短めです。そのため、すべてを理解することはできないかもしれませ
ん。
● どんな事ができるかを体験していただくことがこのハンズオンでは重
要だと考えています。
Copyright © 2021 Toranoana Inc. All Rights Reserved.
4
はじめに
● 途中、マシンのトラブルなどで進められなくなるかもしれません。ある
程度サポートさせていただきますが時間がかかりすぎる場合は、他
の参加者のために先に進ませて頂きます。
○ ハンズオン終了後、共有させていただく資料になぞってご自身
のペースでやっていただけると良いと思います。
● dockerコマンドやdocker-composeコマンドがご用意できていない場
合も見学に切り替えてご参加ください。
Copyright © 2021 Toranoana Inc. All Rights Reserved.
5
事前準備
下記のURLからソースをgit clone または ダウンロードしてください。
https://github.com/toranoana/docker-hands-on
git の場合 下記のコマンド実行
ダウンロードの場合、
「Code」ボタンクリック後、
「Download ZIP」をクリック
ダウンロードしたファイルを解凍
$ git clone https://github.com/toranoana/docker-hands-on
Copyright © 2021 Toranoana Inc. All Rights Reserved.
6
事前準備
STEP1〜STEP7まであります。
このスライドのタイトルにSTEP○とありますので、
対応したソースを使用するようにしてください。
sourcesディレクトリ内に
使用するソースがあります。
README.md には実行するコマンドが
記載されています。
Copyright © 2021 Toranoana Inc. All Rights Reserved.
7
Dockerについて
仮想化技術の一つとしてコンテナがあります。
Dockerはコンテナの一つでありコンテナの中でも最も有名です。
Dockerの特徴
● (VMと比べ)軽量
● 構築内容がコード定義できる
(Infrastructure as Code)
● 複製や再構築が容易
仮想化技術
仮想マシン(VM)
※ホスト型、ハイパーバイ
ザー型などさらに細かい分類
があります
VMWare
VirtualBox 等
コンテナ
Copyright © 2021 Toranoana Inc. All Rights Reserved.
8
Dockerを使ってみる
HelloWorld(STEP1)
Dockerの動作確認
Hello World
$ docker -v
Docker version 20.10.2, build 2291f61
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
$ docker pull hello-world
$ docker run --rm hello-world
Copyright © 2021 Toranoana Inc. All Rights Reserved.
9
Dockerを使ってみる
HelloWorld(STEP1)
Hello Worldの結果
Hello from Docker!
This message shows that your installation appears to be working correctly.
To generate this message, Docker took the following steps:
1. The Docker client contacted the Docker daemon.
2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
(amd64)
3. The Docker daemon created a new container from that image which runs the
executable that produces the output you are currently reading.
4. The Docker daemon streamed that output to the Docker client, which sent it
to your terminal.
To try something more ambitious, you can run an Ubuntu container with:
$ docker run -it ubuntu bash
Share images, automate workflows, and more with a free Docker ID:
https://hub.docker.com/
For more examples and ideas, visit:
https://docs.docker.com/get-started/
Copyright © 2021 Toranoana Inc. All Rights Reserved.
10
Dockerを使ってみる
仕組み説明
解説
Unable to find image 'hello-world:latest' locally
latest: Pulling from library/hello-world
0e03bdcc26d7: Pull complete
Digest: sha256:31b9c7d48790f0d8c50ab433d9c3b7e17666d6993084c002c2ff1ca09b96391d
Status: Downloaded newer image for hello-world:latest
Docker Hub
(https://hub.docker.com/)
hello-worldイメージ
(https://hub.docker.com/_/hello-world)
hello-worldイメージ
ダウンロード(pull)
実行(run)
Copyright © 2021 Toranoana Inc. All Rights Reserved.
11
Dockerを使ってみる
仕組み説明
pullでDocker Hubから「Dockerイメージ」をPCにダウンロード
run で「Dockerイメージ」を元に「Dockerコンテナ」を作成し実行
$ docker pull hello-world
$ docker run --rm hello-world
Copyright © 2021 Toranoana Inc. All Rights Reserved.
12
Dockerを使ってみる
HelloWorld(STEP1)
確認ができたらイメージを削除します。
# 削除
$ docker rmi hello-world
Copyright © 2021 Toranoana Inc. All Rights Reserved.
13
Dockerを使ってみる
Nginx建ててみる(STEP2)
Hello worldだけではつまらないので・・・
Nginxを建ててみる
※81番ポートを既に使っている場合は、81:80の部分を82:80(82番ポートを使用する場合)の様に変えて下さい
Webブラウザで http://localhost:81 に
アクセスしてみて下さい
(ポートを変更した場合は
それに合わせて変えて下さい)
$ docker pull nginx
$ docker run --name hello-nginx -d -p 81:80 nginx
Copyright © 2021 Toranoana Inc. All Rights Reserved.
14
Dockerを使ってみる
Nginx建ててみる(STEP2)
もしこのようなエラーが出る場合はポート(81)を変更してやり直します。
失敗後やり直す場合は先にコンテナを消してから起動します。
$ docker rm hello-nginx -f
$ docker run --name hello-nginx -d -p 82:80 nginx
docker: Error response from daemon: driver failed programming external connectivity on
endpoint hello-nginx (**************): Bind for 0.0.0.0:81 failed: port is already allocated.
Copyright © 2021 Toranoana Inc. All Rights Reserved.
15
Dockerを使ってみる
Nginx建ててみる(STEP2)
確認ができたらコンテナを停止・削除します。
# 停止
$ docker stop hello-nginx
# 削除
$ docker rm hello-nginx
Copyright © 2021 Toranoana Inc. All Rights Reserved.
16
Dockerを使ってみる
Nginx建ててみる(STEP2)
なぜこんなに簡単にnginxが立てられたか
⇒Nginxをセットアップ済みのイメージをNginx公式がDocker Hubに用意してくれ
ているから
Docker Hubには様々なOS、ミドルウェア、データベース、アプリケーションが用
意されていて、コマンド1つだけでそれらをすぐに使うことが出来ます。
確かに簡単ですがこのままだと使い物になりません。
Copyright © 2021 Toranoana Inc. All Rights Reserved.
17
Dockerを使ってみる
Nginx建ててみる(STEP3)
自分で作ったHTMLを表示してみます。
下記のようにファイルを作ります。
html/index.html
Dockerfile
ダウンロードしたソースのこちらを使用します。
https://github.com/toranoana/docker-hands-on/tree/main/step003/sources
Copyright © 2021 Toranoana Inc. All Rights Reserved.
18
Dockerを使ってみる
Nginx建ててみる(STEP3)
Dockerfileの内容
先程動かしたnginxのイメージにファイルをコピーしています。
FROM nginx
COPY ./html /usr/share/nginx/html
Copyright © 2021 Toranoana Inc. All Rights Reserved.
19
Dockerを使ってみる
Nginx建ててみる(STEP3)
html/index.htmlの内容
※好きな内容で構いません。
<html>
<head>
<meta charset="utf-8" />
</head>
<body>こんにちは!</body>
</html>
Copyright © 2021 Toranoana Inc. All Rights Reserved.
20
Dockerを使ってみる
Nginx建ててみる(STEP3)
Dockerfileの内容でコンテナイメージを作成します。
Dockerfileがあるディレクトリで下記を実行します。
イメージが作成できたらそのイメージを実行します。
Webブラウザで http://localhost:81 にアクセスして用意したページが表示されれ
ば成功です
※こちらもポートを変えた場合はそれに合わせて下さい。
$ docker build -t my-nginx .
$ docker run --name hello-nginx -d -p 81:80 my-nginx
Copyright © 2021 Toranoana Inc. All Rights Reserved.
21
Dockerを使ってみる
Nginx建ててみる(STEP3)
Dockerfileを使うことにより、既存のイメージに対して自分でカスタマイズしたイ
メージを作ることができます。
FROMでDocker Hubにある既存のイメージを指定し、COPY命令によりイメージ
に対してファイルを追加しています。
今回はCOPYだけですが、他にも様々な命令を加えることができます。
FROM nginx
COPY ./html /usr/share/nginx/html
Copyright © 2021 Toranoana Inc. All Rights Reserved.
22
Dockerを使ってみる
Nginx建ててみる(STEP3)
確認ができたらコンテナを停止・削除します。
# 停止
$ docker stop hello-nginx
# 削除
$ docker rm hello-nginx
Copyright © 2021 Toranoana Inc. All Rights Reserved.
23
Docker Composeを使ってみる (STEP4)
Docker ComposeとはDockerコンテナを
扱いやすくするツールです。
特に複数コンテナを扱う場合は便利です。
開発においては直接dockerコマンドで操作するよりdocker-composeコ
マンドを使用したほうが楽になります。
Docker Composeの動作確認
$ docker-compose -v
docker-compose version 1.27.4, build 40524192
Copyright © 2021 Toranoana Inc. All Rights Reserved.
24
Docker Composeを使ってみる
Nginx建ててみる(STEP5)
下記のようにファイルを配置・作成します。
html/index.html 、Dockerfile は DockerでNginxを建てたときと同じものです。今
回はdocker-compose.ymlが追加されています。
ダウンロードしたソースのこちらを使用します。
https://github.com/toranoana/docker-hands-on/tree/main/step005-1/sources
Copyright © 2021 Toranoana Inc. All Rights Reserved.
25
Docker Composeを使ってみる
Nginx建ててみる(STEP5)
docker-compose.ymlの内容
インデントはタブではなく空白 2つです。
※YAMLはインデントにタブを使えない仕様になっています
※ここでもポートに気をつけて下さい。
version: '3'
services:
hello-nginx:
build: .
ports:
- '81:80'
Copyright © 2021 Toranoana Inc. All Rights Reserved.
26
Docker Composeを使ってみる
Nginx建ててみる(STEP5)
docker-composeでコンテナイメージを作ります。
docker-compose.ymlがあるディレクトリで下記を実行します。
イメージが作成できたらそのイメージを実行します。
Webブラウザで http://localhost:81 にアクセスして自分の作ったHTMLが表示さ
れれば成功です
※こちらもポートを変えた場合はそちらに合わせて下さい。
$ docker-compose build
$ docker-compose up -d
Copyright © 2021 Toranoana Inc. All Rights Reserved.
27
Docker Composeを使ってみる
Nginx建ててみる(STEP5)
dockerコマンド使用時との比較
dockerコマンド使用時にコマンドラインオプションで
指定した一部の設定をを
docker-composeコマンドでは
yamlファイルに記述出来るように
なっています。
version: '3'
services:
hello-nginx:
build: .
ports:
- '81:80'
$ docker build -t my-nginx .
$ docker run --name hello-nginx -d -p 81:80 my-nginx
$ docker-compose build
$ docker-compose up -d
Copyright © 2021 Toranoana Inc. All Rights Reserved.
28
Docker Composeを使ってみる
Nginx建ててみる(STEP5)
確認ができたら次に行く前にコンテナを停止させて下さい。
$ docker-compose stop
Copyright © 2021 Toranoana Inc. All Rights Reserved.
29
Docker Composeを使ってみる
Nginx建ててみる(STEP5)
html/index.htmlの内容を変えて確認したい場合毎回コンテナ内にコピーしなくて
はなりません。開発時においてそれはかなり面倒です。
そんな時はVolumeを使うと便利です。
docker-compose.ymlに赤字部分を追加して下さい
version: '3'
services:
hello-nginx:
build: .
ports:
- '81:80'
volumes:
- ./html:/usr/share/nginx/html
Copyright © 2021 Toranoana Inc. All Rights Reserved.
30
Docker Composeを使ってみる
Nginx建ててみる(STEP5)
もう一度コンテナを起動します。
Webブラウザで http://localhost:81 にアクセスして表示内容確認後、
html/index.htmlの内容を変更してブラウザをリロードしてみて下さい。
すぐに変更内容が反映されているはずです。
※Volumeはdockerコマンドでも使用できますがdocker-composeで管理したほ
うが楽にできます。
$ docker-compose up -d
Copyright © 2021 Toranoana Inc. All Rights Reserved.
31
Docker Composeを使ってみる
Nginx建ててみる(STEP5)
確認ができたらコンテナを停止・削除します。
# 停止
$ docker-compose stop
# 削除
$ docker-compose down
Copyright © 2021 Toranoana Inc. All Rights Reserved.
32
Docker Composeを使ってみる
MySQL建ててみる(STEP6)
次は少しファイルの記述量が多いのでスライドに表示するのは省略します。
git clone あるいは ダウンロードしたファイルを確認してください。
https://github.com/toranoana/docker-hands-on/blob/main/step006/sources/d
ocker-compose.yml
Copyright © 2021 Toranoana Inc. All Rights Reserved.
33
Docker Composeを使ってみる
MySQL建ててみる(STEP6)
今回はMySQL 5.7を使用しています。
コンテナイメージにはいくつかのバージョンを用意してくれているものもあり、イ
メージ名の後に:(コロン)を付けてタグ名を指定することで、特定のバージョンを使
用することができます。
タグ名を省略した場合はlatestという名前のタグが使用されています。
※前のSTEPで実行しているnginxは本当はnginx:latestを使っていました。
使用できるタグはDocker Hubのページに載せられています
MySQLの公式イメージのページ
https://hub.docker.com/_/mysql
Copyright © 2021 Toranoana Inc. All Rights Reserved.
34
Docker Composeを使ってみる
MySQL建ててみる(STEP6)
コンテナを起動します。
Webブラウザで http://localhost:1080 にアクセスしてします。
phpMyAdminによりWebブラウザからMySQLの操作ができます。
$ docker-compose pull
$ docker-compose up -d
Copyright © 2021 Toranoana Inc. All Rights Reserved.
35
Docker Composeを使ってみる
MySQL建ててみる(STEP6)
確認ができたら次に行く前にコンテナを停止・削除します。
# 停止
$ docker-compose stop
# 削除
$ docker-compose down
Copyright © 2021 Toranoana Inc. All Rights Reserved.
36
Railsアプリケーション構築(STEP7)
次もファイルの記述量が多いのでスライドに表示するのは省略します。
git clone あるいは ダウンロードしたファイルを確認してください。
https://github.com/toranoana/docker-hands-on/blob/main/step007/sources/d
ocker-compose.yml
https://github.com/toranoana/docker-hands-on/blob/main/step007/sources/
Dockerfile
Copyright © 2021 Toranoana Inc. All Rights Reserved.
37
Railsアプリケーション構築(STEP7)
docker-composeでコンテナイメージを作ります。
docker-compose.ymlがあるディレクトリで下記を実行します。
イメージが作成できたらそのイメージを実行します。
下記のコマンドでコンテナ内に入ります
$ docker-compose pull
$ docker-compose build
$ docker-compose up -d
$ docker-compose exec my-app bash
Copyright © 2021 Toranoana Inc. All Rights Reserved.
38
Railsアプリケーション構築(STEP7)
下記のコマンドでRailsアプリケーションを作成します。
作成が終わったらテキストエディタで config/database.yml を開き、データベース
接続設定を変更します。
変更前
変更後
$ rails new . -d mysql -S -J
host: localhost
host: my-database
Copyright © 2021 Toranoana Inc. All Rights Reserved.
39
Railsアプリケーション構築(STEP7)
docker-composeで管理しているコンテナ同士は
docker-compose.ymlで定義した名前のサービス名をホストとして接続できます。
先程、localhostをmy-databaseに変えたのはアプリケーションの外に作った別のコンテナの
DBへ接続するためです。
version: '3'
services:
my-app:
# ...
my-database:
# ...
Copyright © 2021 Toranoana Inc. All Rights Reserved.
40
Railsアプリケーション構築(STEP7)
下記のコマンドでRailsアプリケーションを起動します。
起動後 http://localhost:3000 を開きます。
※停止させる場合はCtrl + C
rails db:create
rails db:migrate
rails server --binding=0.0.0.0
Copyright © 2021 Toranoana Inc. All Rights Reserved.
41
Railsアプリケーション構築(STEP7)
データベースに接続する処理を追加するため下記を実行します。
起動後 http://localhost:3000/users を開きます。
※停止させる場合はCtrl + C
rails generate scaffold user name:string
rails db:migrate
rails server --binding=0.0.0.0
Copyright © 2021 Toranoana Inc. All Rights Reserved.
42
Railsアプリケーション構築(STEP7)
確認ができたらコンテナを停止・削除します。
# コンテナから出る
$ exit
# 停止
$ docker-compose stop
# 削除
$ docker-compose down
Copyright © 2021 Toranoana Inc. All Rights Reserved.
youtube宣伝
虎の穴ラボでは
採用説明や勉強会などのオンラインイベントを
youtubeから配信していきます。
よろしければ「いいね!」やチャンネル登録を
お願い致します。
https://www.youtube.com/channel/UC2LQCTWBg7da5JHxQ
dGNGyw
43
Copyright © 2021 Toranoana Inc. All Rights Reserved.
youtube宣伝
虎の穴ラボのエンジニアが業務や技術・働き方についてざっくばらんにお届けする配信番組です。
感想やフィードバックをTwitterのハッシュタグ「#ToraLab_fm」でお待ちしています!
Youtubeチャンネルと下記のPodcastで配信しています。
https://anchor.fm/toranoanalab
44
Copyright © 2021 Toranoana Inc. All Rights Reserved.
質問受付
45

More Related Content

PPT
Sintese de proteina 2
PDF
Palmeiras nativas do brasil
PPTX
As Plantas, Folha E Flor
PPTX
Cromatografia Líquida Classica
PPT
Replicacao e transcriçao DNA procariotos
PDF
Diferenciação celular
PDF
Biologia 12 ciclo sexual
PPT
Replicação dna marília
Sintese de proteina 2
Palmeiras nativas do brasil
As Plantas, Folha E Flor
Cromatografia Líquida Classica
Replicacao e transcriçao DNA procariotos
Diferenciação celular
Biologia 12 ciclo sexual
Replicação dna marília

What's hot (20)

PPT
Microscópio Óptico
PPT
Gimnosperma e angiosperma
PPT
Hormonas vegetais %2890 min%29
PPTX
Agricultura de Precisão - UFCG Pombal
PPTX
Deficiencia Nutricional ou Doença
DOC
Separação de Aminoácidos por Cromatografia em 4 papel
PPT
Brassinosteroides poliaminas acido jasmonico e acido salicilico
PPSX
Trabalho final v2 final
PDF
Regiões agro ecológicas de moçambique pdf
PDF
Ciclo das rochas ou ciclo litológicos - Geologia 10
PDF
Nós e Amarrações
PPT
Aula molecular 1
PDF
Transaminação de aminoácidos
PDF
Geo 14 - Formação de Minerais
PDF
BG11_T1a_2021_CC.pdf
PDF
3S_Ciência forense
PPT
Produção Proteínas Recombinantes
PPTX
Origem da vida na terra (1ª aula)
PPT
Vidrarias materias cuidados básicos
Microscópio Óptico
Gimnosperma e angiosperma
Hormonas vegetais %2890 min%29
Agricultura de Precisão - UFCG Pombal
Deficiencia Nutricional ou Doença
Separação de Aminoácidos por Cromatografia em 4 papel
Brassinosteroides poliaminas acido jasmonico e acido salicilico
Trabalho final v2 final
Regiões agro ecológicas de moçambique pdf
Ciclo das rochas ou ciclo litológicos - Geologia 10
Nós e Amarrações
Aula molecular 1
Transaminação de aminoácidos
Geo 14 - Formação de Minerais
BG11_T1a_2021_CC.pdf
3S_Ciência forense
Produção Proteínas Recombinantes
Origem da vida na terra (1ª aula)
Vidrarias materias cuidados básicos
Ad

Similar to Webアプリケーション開発者のためのDockerハンズオン (20)

PDF
Webアプリケーション開発者のためのDockerハンズオン20210519
PDF
Docker handson
PDF
今だからこそ知りたい Docker Compose/Swarm 入門
PPTX
Docker超入門
PPTX
Docker & Kubernetes基礎
PPTX
20230128.pptx
PDF
オトナのDocker入門
PDF
Docker講習会資料
PDF
Docker/Aarukas入門ハンズオン資料~第1回さくらとコンテナの夕べ #さくらの夕べ 番外編
PDF
Introduce that Best practices for writing Dockerfiles
PDF
Dockerライフサイクルの基礎 地雷を踏み抜けろ!
PDF
Docker入門: コンテナ型仮想化技術の仕組みと使い方
PDF
Docker実践入門
PDF
Dockerでらくらく開発・運用を体感しよう
PDF
Docker 再入門 2016 update
PDF
20170124 linux basic_2
PPTX
ラズパイ2で動く Docker PaaS
PPTX
Newcomer2020 Docker研修
PDF
Rancher/Kubernetes入門ハンズオン資料~第2回さくらとコンテナの夕べ #さくらの夕べ 番外編
PPTX
Docker入門
Webアプリケーション開発者のためのDockerハンズオン20210519
Docker handson
今だからこそ知りたい Docker Compose/Swarm 入門
Docker超入門
Docker & Kubernetes基礎
20230128.pptx
オトナのDocker入門
Docker講習会資料
Docker/Aarukas入門ハンズオン資料~第1回さくらとコンテナの夕べ #さくらの夕べ 番外編
Introduce that Best practices for writing Dockerfiles
Dockerライフサイクルの基礎 地雷を踏み抜けろ!
Docker入門: コンテナ型仮想化技術の仕組みと使い方
Docker実践入門
Dockerでらくらく開発・運用を体感しよう
Docker 再入門 2016 update
20170124 linux basic_2
ラズパイ2で動く Docker PaaS
Newcomer2020 Docker研修
Rancher/Kubernetes入門ハンズオン資料~第2回さくらとコンテナの夕べ #さくらの夕べ 番外編
Docker入門
Ad

More from 虎の穴 開発室 (20)

PDF
FizzBuzzで学ぶJavaの進化
PDF
Railsのデバッグ どうやるかを改めて確認する
PDF
虎の穴ラボ エンジニア採用説明資料 .pdf
PDF
Deno Deployと組み合わせるのに Upstashをおすすめしたい.pdf
PDF
toranoana.deno #6 アジェンダ 採用説明
PDF
Deno 向け WEB 開発用のツールを作ったので 紹介します
PDF
Supabase Edge Functions と Netlify Edge Functions を使ってみる – 機能とその比較 –
PDF
GCPの画像認識APIの紹介
PDF
【エンジニアの勉強法ハックLT- vol.7】ゲームから学んだ勉強のこと
PDF
GitHub APIとfreshで遊ぼう
PDF
通販開発部の西田さん「通販開発マネジメントの5ルール」
PDF
社内DX推進!非エンジニア向けにプログラミング講座を実施してみた!
PDF
セキュリティを強化しよう!CloudArmorの機能解説
PDF
JavaScript LT会 〜 React.js Node.js歓迎 〜 Deno で やってみるweb開発
PDF
Amplify Studioを使ってみた
PDF
いいテスト会 (スプリントレビュー) をやろう!
PDF
【Saitama.js】Denoのすすめ
PDF
虎の穴ラボ Tech day#3 チームで戦う!とらのあな通販冬の大感謝祭でのフロント開発について
PDF
【とらのあなラボ Tech Day #3】新規システムにおける技術選定〜GoとgRPCを採用した話〜
PDF
虎の穴ラボ TechDay#3 フルリモート率100%!リモートワークを可能にするマネージメント
FizzBuzzで学ぶJavaの進化
Railsのデバッグ どうやるかを改めて確認する
虎の穴ラボ エンジニア採用説明資料 .pdf
Deno Deployと組み合わせるのに Upstashをおすすめしたい.pdf
toranoana.deno #6 アジェンダ 採用説明
Deno 向け WEB 開発用のツールを作ったので 紹介します
Supabase Edge Functions と Netlify Edge Functions を使ってみる – 機能とその比較 –
GCPの画像認識APIの紹介
【エンジニアの勉強法ハックLT- vol.7】ゲームから学んだ勉強のこと
GitHub APIとfreshで遊ぼう
通販開発部の西田さん「通販開発マネジメントの5ルール」
社内DX推進!非エンジニア向けにプログラミング講座を実施してみた!
セキュリティを強化しよう!CloudArmorの機能解説
JavaScript LT会 〜 React.js Node.js歓迎 〜 Deno で やってみるweb開発
Amplify Studioを使ってみた
いいテスト会 (スプリントレビュー) をやろう!
【Saitama.js】Denoのすすめ
虎の穴ラボ Tech day#3 チームで戦う!とらのあな通販冬の大感謝祭でのフロント開発について
【とらのあなラボ Tech Day #3】新規システムにおける技術選定〜GoとgRPCを採用した話〜
虎の穴ラボ TechDay#3 フルリモート率100%!リモートワークを可能にするマネージメント

Webアプリケーション開発者のためのDockerハンズオン

  • 1. Copyright © 2021 Toranoana Inc. All Rights Reserved. Webアプリケーション開発者のための Docker, Docker Composeハンズオン 虎の穴ラボ はっとり 1
  • 2. Copyright © 2021 Toranoana Inc. All Rights Reserved. 2 目次 ● はじめに・事前準備 ● Dockerについて(5分) ● Dockerを使ってみる(15分) ○ HelloWorld ○ 仕組み説明 ○ Nginx建ててみるDocker編 ● Docker Composeを使ってみる(15分) ○ Nginx建ててみるDocker Compose編 ○ MySQLを建ててみる ● Railsアプリケーション構築(15分)
  • 3. Copyright © 2021 Toranoana Inc. All Rights Reserved. 3 はじめに ● このハンズオンはDockerを体験することを重視しているので解説は 短めです。そのため、すべてを理解することはできないかもしれませ ん。 ● どんな事ができるかを体験していただくことがこのハンズオンでは重 要だと考えています。
  • 4. Copyright © 2021 Toranoana Inc. All Rights Reserved. 4 はじめに ● 途中、マシンのトラブルなどで進められなくなるかもしれません。ある 程度サポートさせていただきますが時間がかかりすぎる場合は、他 の参加者のために先に進ませて頂きます。 ○ ハンズオン終了後、共有させていただく資料になぞってご自身 のペースでやっていただけると良いと思います。 ● dockerコマンドやdocker-composeコマンドがご用意できていない場 合も見学に切り替えてご参加ください。
  • 5. Copyright © 2021 Toranoana Inc. All Rights Reserved. 5 事前準備 下記のURLからソースをgit clone または ダウンロードしてください。 https://github.com/toranoana/docker-hands-on git の場合 下記のコマンド実行 ダウンロードの場合、 「Code」ボタンクリック後、 「Download ZIP」をクリック ダウンロードしたファイルを解凍 $ git clone https://github.com/toranoana/docker-hands-on
  • 6. Copyright © 2021 Toranoana Inc. All Rights Reserved. 6 事前準備 STEP1〜STEP7まであります。 このスライドのタイトルにSTEP○とありますので、 対応したソースを使用するようにしてください。 sourcesディレクトリ内に 使用するソースがあります。 README.md には実行するコマンドが 記載されています。
  • 7. Copyright © 2021 Toranoana Inc. All Rights Reserved. 7 Dockerについて 仮想化技術の一つとしてコンテナがあります。 Dockerはコンテナの一つでありコンテナの中でも最も有名です。 Dockerの特徴 ● (VMと比べ)軽量 ● 構築内容がコード定義できる (Infrastructure as Code) ● 複製や再構築が容易 仮想化技術 仮想マシン(VM) ※ホスト型、ハイパーバイ ザー型などさらに細かい分類 があります VMWare VirtualBox 等 コンテナ
  • 8. Copyright © 2021 Toranoana Inc. All Rights Reserved. 8 Dockerを使ってみる HelloWorld(STEP1) Dockerの動作確認 Hello World $ docker -v Docker version 20.10.2, build 2291f61 $ docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES $ docker pull hello-world $ docker run --rm hello-world
  • 9. Copyright © 2021 Toranoana Inc. All Rights Reserved. 9 Dockerを使ってみる HelloWorld(STEP1) Hello Worldの結果 Hello from Docker! This message shows that your installation appears to be working correctly. To generate this message, Docker took the following steps: 1. The Docker client contacted the Docker daemon. 2. The Docker daemon pulled the "hello-world" image from the Docker Hub. (amd64) 3. The Docker daemon created a new container from that image which runs the executable that produces the output you are currently reading. 4. The Docker daemon streamed that output to the Docker client, which sent it to your terminal. To try something more ambitious, you can run an Ubuntu container with: $ docker run -it ubuntu bash Share images, automate workflows, and more with a free Docker ID: https://hub.docker.com/ For more examples and ideas, visit: https://docs.docker.com/get-started/
  • 10. Copyright © 2021 Toranoana Inc. All Rights Reserved. 10 Dockerを使ってみる 仕組み説明 解説 Unable to find image 'hello-world:latest' locally latest: Pulling from library/hello-world 0e03bdcc26d7: Pull complete Digest: sha256:31b9c7d48790f0d8c50ab433d9c3b7e17666d6993084c002c2ff1ca09b96391d Status: Downloaded newer image for hello-world:latest Docker Hub (https://hub.docker.com/) hello-worldイメージ (https://hub.docker.com/_/hello-world) hello-worldイメージ ダウンロード(pull) 実行(run)
  • 11. Copyright © 2021 Toranoana Inc. All Rights Reserved. 11 Dockerを使ってみる 仕組み説明 pullでDocker Hubから「Dockerイメージ」をPCにダウンロード run で「Dockerイメージ」を元に「Dockerコンテナ」を作成し実行 $ docker pull hello-world $ docker run --rm hello-world
  • 12. Copyright © 2021 Toranoana Inc. All Rights Reserved. 12 Dockerを使ってみる HelloWorld(STEP1) 確認ができたらイメージを削除します。 # 削除 $ docker rmi hello-world
  • 13. Copyright © 2021 Toranoana Inc. All Rights Reserved. 13 Dockerを使ってみる Nginx建ててみる(STEP2) Hello worldだけではつまらないので・・・ Nginxを建ててみる ※81番ポートを既に使っている場合は、81:80の部分を82:80(82番ポートを使用する場合)の様に変えて下さい Webブラウザで http://localhost:81 に アクセスしてみて下さい (ポートを変更した場合は それに合わせて変えて下さい) $ docker pull nginx $ docker run --name hello-nginx -d -p 81:80 nginx
  • 14. Copyright © 2021 Toranoana Inc. All Rights Reserved. 14 Dockerを使ってみる Nginx建ててみる(STEP2) もしこのようなエラーが出る場合はポート(81)を変更してやり直します。 失敗後やり直す場合は先にコンテナを消してから起動します。 $ docker rm hello-nginx -f $ docker run --name hello-nginx -d -p 82:80 nginx docker: Error response from daemon: driver failed programming external connectivity on endpoint hello-nginx (**************): Bind for 0.0.0.0:81 failed: port is already allocated.
  • 15. Copyright © 2021 Toranoana Inc. All Rights Reserved. 15 Dockerを使ってみる Nginx建ててみる(STEP2) 確認ができたらコンテナを停止・削除します。 # 停止 $ docker stop hello-nginx # 削除 $ docker rm hello-nginx
  • 16. Copyright © 2021 Toranoana Inc. All Rights Reserved. 16 Dockerを使ってみる Nginx建ててみる(STEP2) なぜこんなに簡単にnginxが立てられたか ⇒Nginxをセットアップ済みのイメージをNginx公式がDocker Hubに用意してくれ ているから Docker Hubには様々なOS、ミドルウェア、データベース、アプリケーションが用 意されていて、コマンド1つだけでそれらをすぐに使うことが出来ます。 確かに簡単ですがこのままだと使い物になりません。
  • 17. Copyright © 2021 Toranoana Inc. All Rights Reserved. 17 Dockerを使ってみる Nginx建ててみる(STEP3) 自分で作ったHTMLを表示してみます。 下記のようにファイルを作ります。 html/index.html Dockerfile ダウンロードしたソースのこちらを使用します。 https://github.com/toranoana/docker-hands-on/tree/main/step003/sources
  • 18. Copyright © 2021 Toranoana Inc. All Rights Reserved. 18 Dockerを使ってみる Nginx建ててみる(STEP3) Dockerfileの内容 先程動かしたnginxのイメージにファイルをコピーしています。 FROM nginx COPY ./html /usr/share/nginx/html
  • 19. Copyright © 2021 Toranoana Inc. All Rights Reserved. 19 Dockerを使ってみる Nginx建ててみる(STEP3) html/index.htmlの内容 ※好きな内容で構いません。 <html> <head> <meta charset="utf-8" /> </head> <body>こんにちは!</body> </html>
  • 20. Copyright © 2021 Toranoana Inc. All Rights Reserved. 20 Dockerを使ってみる Nginx建ててみる(STEP3) Dockerfileの内容でコンテナイメージを作成します。 Dockerfileがあるディレクトリで下記を実行します。 イメージが作成できたらそのイメージを実行します。 Webブラウザで http://localhost:81 にアクセスして用意したページが表示されれ ば成功です ※こちらもポートを変えた場合はそれに合わせて下さい。 $ docker build -t my-nginx . $ docker run --name hello-nginx -d -p 81:80 my-nginx
  • 21. Copyright © 2021 Toranoana Inc. All Rights Reserved. 21 Dockerを使ってみる Nginx建ててみる(STEP3) Dockerfileを使うことにより、既存のイメージに対して自分でカスタマイズしたイ メージを作ることができます。 FROMでDocker Hubにある既存のイメージを指定し、COPY命令によりイメージ に対してファイルを追加しています。 今回はCOPYだけですが、他にも様々な命令を加えることができます。 FROM nginx COPY ./html /usr/share/nginx/html
  • 22. Copyright © 2021 Toranoana Inc. All Rights Reserved. 22 Dockerを使ってみる Nginx建ててみる(STEP3) 確認ができたらコンテナを停止・削除します。 # 停止 $ docker stop hello-nginx # 削除 $ docker rm hello-nginx
  • 23. Copyright © 2021 Toranoana Inc. All Rights Reserved. 23 Docker Composeを使ってみる (STEP4) Docker ComposeとはDockerコンテナを 扱いやすくするツールです。 特に複数コンテナを扱う場合は便利です。 開発においては直接dockerコマンドで操作するよりdocker-composeコ マンドを使用したほうが楽になります。 Docker Composeの動作確認 $ docker-compose -v docker-compose version 1.27.4, build 40524192
  • 24. Copyright © 2021 Toranoana Inc. All Rights Reserved. 24 Docker Composeを使ってみる Nginx建ててみる(STEP5) 下記のようにファイルを配置・作成します。 html/index.html 、Dockerfile は DockerでNginxを建てたときと同じものです。今 回はdocker-compose.ymlが追加されています。 ダウンロードしたソースのこちらを使用します。 https://github.com/toranoana/docker-hands-on/tree/main/step005-1/sources
  • 25. Copyright © 2021 Toranoana Inc. All Rights Reserved. 25 Docker Composeを使ってみる Nginx建ててみる(STEP5) docker-compose.ymlの内容 インデントはタブではなく空白 2つです。 ※YAMLはインデントにタブを使えない仕様になっています ※ここでもポートに気をつけて下さい。 version: '3' services: hello-nginx: build: . ports: - '81:80'
  • 26. Copyright © 2021 Toranoana Inc. All Rights Reserved. 26 Docker Composeを使ってみる Nginx建ててみる(STEP5) docker-composeでコンテナイメージを作ります。 docker-compose.ymlがあるディレクトリで下記を実行します。 イメージが作成できたらそのイメージを実行します。 Webブラウザで http://localhost:81 にアクセスして自分の作ったHTMLが表示さ れれば成功です ※こちらもポートを変えた場合はそちらに合わせて下さい。 $ docker-compose build $ docker-compose up -d
  • 27. Copyright © 2021 Toranoana Inc. All Rights Reserved. 27 Docker Composeを使ってみる Nginx建ててみる(STEP5) dockerコマンド使用時との比較 dockerコマンド使用時にコマンドラインオプションで 指定した一部の設定をを docker-composeコマンドでは yamlファイルに記述出来るように なっています。 version: '3' services: hello-nginx: build: . ports: - '81:80' $ docker build -t my-nginx . $ docker run --name hello-nginx -d -p 81:80 my-nginx $ docker-compose build $ docker-compose up -d
  • 28. Copyright © 2021 Toranoana Inc. All Rights Reserved. 28 Docker Composeを使ってみる Nginx建ててみる(STEP5) 確認ができたら次に行く前にコンテナを停止させて下さい。 $ docker-compose stop
  • 29. Copyright © 2021 Toranoana Inc. All Rights Reserved. 29 Docker Composeを使ってみる Nginx建ててみる(STEP5) html/index.htmlの内容を変えて確認したい場合毎回コンテナ内にコピーしなくて はなりません。開発時においてそれはかなり面倒です。 そんな時はVolumeを使うと便利です。 docker-compose.ymlに赤字部分を追加して下さい version: '3' services: hello-nginx: build: . ports: - '81:80' volumes: - ./html:/usr/share/nginx/html
  • 30. Copyright © 2021 Toranoana Inc. All Rights Reserved. 30 Docker Composeを使ってみる Nginx建ててみる(STEP5) もう一度コンテナを起動します。 Webブラウザで http://localhost:81 にアクセスして表示内容確認後、 html/index.htmlの内容を変更してブラウザをリロードしてみて下さい。 すぐに変更内容が反映されているはずです。 ※Volumeはdockerコマンドでも使用できますがdocker-composeで管理したほ うが楽にできます。 $ docker-compose up -d
  • 31. Copyright © 2021 Toranoana Inc. All Rights Reserved. 31 Docker Composeを使ってみる Nginx建ててみる(STEP5) 確認ができたらコンテナを停止・削除します。 # 停止 $ docker-compose stop # 削除 $ docker-compose down
  • 32. Copyright © 2021 Toranoana Inc. All Rights Reserved. 32 Docker Composeを使ってみる MySQL建ててみる(STEP6) 次は少しファイルの記述量が多いのでスライドに表示するのは省略します。 git clone あるいは ダウンロードしたファイルを確認してください。 https://github.com/toranoana/docker-hands-on/blob/main/step006/sources/d ocker-compose.yml
  • 33. Copyright © 2021 Toranoana Inc. All Rights Reserved. 33 Docker Composeを使ってみる MySQL建ててみる(STEP6) 今回はMySQL 5.7を使用しています。 コンテナイメージにはいくつかのバージョンを用意してくれているものもあり、イ メージ名の後に:(コロン)を付けてタグ名を指定することで、特定のバージョンを使 用することができます。 タグ名を省略した場合はlatestという名前のタグが使用されています。 ※前のSTEPで実行しているnginxは本当はnginx:latestを使っていました。 使用できるタグはDocker Hubのページに載せられています MySQLの公式イメージのページ https://hub.docker.com/_/mysql
  • 34. Copyright © 2021 Toranoana Inc. All Rights Reserved. 34 Docker Composeを使ってみる MySQL建ててみる(STEP6) コンテナを起動します。 Webブラウザで http://localhost:1080 にアクセスしてします。 phpMyAdminによりWebブラウザからMySQLの操作ができます。 $ docker-compose pull $ docker-compose up -d
  • 35. Copyright © 2021 Toranoana Inc. All Rights Reserved. 35 Docker Composeを使ってみる MySQL建ててみる(STEP6) 確認ができたら次に行く前にコンテナを停止・削除します。 # 停止 $ docker-compose stop # 削除 $ docker-compose down
  • 36. Copyright © 2021 Toranoana Inc. All Rights Reserved. 36 Railsアプリケーション構築(STEP7) 次もファイルの記述量が多いのでスライドに表示するのは省略します。 git clone あるいは ダウンロードしたファイルを確認してください。 https://github.com/toranoana/docker-hands-on/blob/main/step007/sources/d ocker-compose.yml https://github.com/toranoana/docker-hands-on/blob/main/step007/sources/ Dockerfile
  • 37. Copyright © 2021 Toranoana Inc. All Rights Reserved. 37 Railsアプリケーション構築(STEP7) docker-composeでコンテナイメージを作ります。 docker-compose.ymlがあるディレクトリで下記を実行します。 イメージが作成できたらそのイメージを実行します。 下記のコマンドでコンテナ内に入ります $ docker-compose pull $ docker-compose build $ docker-compose up -d $ docker-compose exec my-app bash
  • 38. Copyright © 2021 Toranoana Inc. All Rights Reserved. 38 Railsアプリケーション構築(STEP7) 下記のコマンドでRailsアプリケーションを作成します。 作成が終わったらテキストエディタで config/database.yml を開き、データベース 接続設定を変更します。 変更前 変更後 $ rails new . -d mysql -S -J host: localhost host: my-database
  • 39. Copyright © 2021 Toranoana Inc. All Rights Reserved. 39 Railsアプリケーション構築(STEP7) docker-composeで管理しているコンテナ同士は docker-compose.ymlで定義した名前のサービス名をホストとして接続できます。 先程、localhostをmy-databaseに変えたのはアプリケーションの外に作った別のコンテナの DBへ接続するためです。 version: '3' services: my-app: # ... my-database: # ...
  • 40. Copyright © 2021 Toranoana Inc. All Rights Reserved. 40 Railsアプリケーション構築(STEP7) 下記のコマンドでRailsアプリケーションを起動します。 起動後 http://localhost:3000 を開きます。 ※停止させる場合はCtrl + C rails db:create rails db:migrate rails server --binding=0.0.0.0
  • 41. Copyright © 2021 Toranoana Inc. All Rights Reserved. 41 Railsアプリケーション構築(STEP7) データベースに接続する処理を追加するため下記を実行します。 起動後 http://localhost:3000/users を開きます。 ※停止させる場合はCtrl + C rails generate scaffold user name:string rails db:migrate rails server --binding=0.0.0.0
  • 42. Copyright © 2021 Toranoana Inc. All Rights Reserved. 42 Railsアプリケーション構築(STEP7) 確認ができたらコンテナを停止・削除します。 # コンテナから出る $ exit # 停止 $ docker-compose stop # 削除 $ docker-compose down
  • 43. Copyright © 2021 Toranoana Inc. All Rights Reserved. youtube宣伝 虎の穴ラボでは 採用説明や勉強会などのオンラインイベントを youtubeから配信していきます。 よろしければ「いいね!」やチャンネル登録を お願い致します。 https://www.youtube.com/channel/UC2LQCTWBg7da5JHxQ dGNGyw 43
  • 44. Copyright © 2021 Toranoana Inc. All Rights Reserved. youtube宣伝 虎の穴ラボのエンジニアが業務や技術・働き方についてざっくばらんにお届けする配信番組です。 感想やフィードバックをTwitterのハッシュタグ「#ToraLab_fm」でお待ちしています! Youtubeチャンネルと下記のPodcastで配信しています。 https://anchor.fm/toranoanalab 44
  • 45. Copyright © 2021 Toranoana Inc. All Rights Reserved. 質問受付 45