66
58

More than 1 year has passed since last update.

【Docker初心者】Dockerfileの書き方について

Last updated at Posted at 2023-06-04

1.はじめに

最近、山浦清透さんが運営されているプログラミング学習サービス「独学エンジニア」にてDockerについて学び始めました(^o^)
講義内容とほとんど同じになりますが、備忘録も兼ねて自分なりにまとめていきたいと思います。
今回の内容はDockerの基本操作を理解した上での記事となりますので、まだ分からないって方は以前投稿した記事、「Docker基本操作Part1」「Docker基本操作Part2」を軽くご一読ください。

docker_logo_icon_169251.png

2.Dockerfileとは

Dockerfileとは、Dockerイメージを作成するためのテキストファイルです。
Dockerfile内には、基本となるOS、インストールする必要があるソフトウェア、コピーするファイル・ディレクトリ、開くポート、実行するコマンドなど、新しいDockerイメージを作成するために必要な指示が含まれています。
Dockerfileの書き方としては、「FROM」,「RUN」,「CMD」などのインストラクションに引数を記述し、作成します。

コンテナ(5).png

3.各インストラクションについて

(1) FROM

「FROM」インストラクションはDockerfileの中で一番最初に記述されるべき命令で、新たに作成するDockerイメージのベースとなるイメージを指定します。
また、ベースイメージはDockerHubを参考にします。

FROM:インストラクション
# 書式: FROM [イメージ] [タグ]
$ FROM ubuntu:22.10

「FROM」インストラクションの後にはイメージ名とタグを指定します。
イメージ名はそのイメージが何を表しているのか(例えば、Ubuntu,Node.js,Rubyなど)を示し、タグはそのイメージのバージョンを表します。

(2) RUN

「RUN」インストラクションはDockerイメージのビルド時にシェルコマンドを実行するための命令です。
この命令を使用することで、イメージにソフトウェアをインストールしたり、セットアップの手順を実行したりすることができます。

RUN:インストラクション
# 書式: RUN [コマンド] 
$ RUN apt update \
    && apt install -y apache2

「RUN」インストラクションは実行ごとに新しいレイヤを作成してその上でコマンドを実行するため、多くの「RUN」を持つDockerfileは多くのレイヤから成るイメージを作成し、イメージのサイズが大きくなります。しかし、レイヤ数が多いと、PCの容量が圧迫されたり、イメージのビルドに時間がかかったりするため、レイヤ数は最小限にすることが望ましいです。
このため、複数のコマンドを一度にまとめて実行するときは「&&」で繋ぎ、「RUN」を減らし、複数行になるときは「\」(バックスラッシュ)で繋げることにより見やすくしましょう。

(3) CMD

「CMD」インストラクションは、Dockerコンテナが実行されたときにデフォルトで実行するコマンドを定義します。

CMD:インストラクション
# 書式: CMD ["実行ファイル", "パラメータ1","パラメータ2"] 
$ CMD ["apachectl","-D","FOREGROUND"]

CMDの指定方法にはexec形式とshell形式の2種類あり、基本的にはexec形式を使います。
[]で囲み、一つずつパラメータをダブルクオーテーションで囲むことに注意しましょう。

RUNとCMDの違いとは?
インストラクションで受け取る引数にあるコマンドを実行する点では似ている「RUN」と「CMD」ですが、大きな違いは「RUNはレイヤを作る」、「CMDはレイヤを作らない」ことです。
レイヤは再生可能であり、Dockerは一度ビルドされたレイヤをキャッシュして再利用することができるため、ソフトウェアのインストールやファイルのコピーなどイメージの構築に必要な手順を「RUN」で指示することによりベースイメージにキャッシュさせ覚えさせることで、何度もダウンロードせず済みます。

(4) COPY

「COPY」インストラクションは、ホスト(ローカル)のファイルやディレクトリをDockerイメージにコピーします。
具体的な使い方としては、ソースコードや設定ファイルはローカルで作成して、COPYを使ってDockerイメージにコピーして使用します。

COPY:インストラクション
# 書式: COPY [コピー元][コピー先] 
①ファイルをファイルに
$ COPY index.html /mydir/index.html 
②ファイルをディレクトリ以下に
$ COPY index.html /mydir/ 
③ディレクトリをディレクトリに            
$ COPY src/ /mydir/

(5) ENV

「ENV」インストラクションは、Dockerfile内で環境変数を設定するために使用されます。
設定された環境変数は、その後のDockerfileの中で使用することができ、また生成されたDockerイメージから作成される全てのコンテナで利用可能です。

ENV:インストラクション
# 書式: ENV [キー] = [値] 
$ ENV MYSQL_USER=admin
$ ENV MYSQL_PASSWORD=password

(6) WORKDIR

「WORKDIR」インストラクションは、コマンドを実行する作業ディレクトリを指定します。

WORKDIR:インストラクション
# 書式: WORKDIR [ディレクトリのパス] 
$ WORKDIR /app

「WORKDIR」インストラクションを使用することで、Dockerfileが読みやすくなり、絶対パスを何度も書く手間が省くこともできるので、適切に使っていきましょう。

4.おわりに

最後まで見ていただき、ありがとうございました!
自分で作成しながらまとめることで、より理解が深まったと思います(^^)
次回は、「Docker Composeについて」まとめることができればと思います!

5.参考資料

66
58
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
66
58