Fedora 34
Sponsored Link

Podman : Dockerfile を利用する
2021/05/14
 
Dockerfile を利用してコンテナーイメージを作成し、コンテナーを実行します。
Dockerfile にはコンテナーの構成内容をまとめて記述するため、構成管理にも役立ちます。
[1] 例として、Nginx のインストールと起動を行う Dockerfile を作成します。
[root@dlp ~]#
vi Dockerfile
# 新規作成

FROM fedora
MAINTAINER ServerWorld <admin@srv.world>

RUN dnf -y install nginx
RUN echo "Dockerfile Test on Nginx" > /usr/share/nginx/html/index.html

EXPOSE 80
CMD ["/usr/sbin/nginx", "-g", "daemon off;"]

# イメージのビルド ⇒ docker build -t [イメージ名]:[タグ] .

[root@dlp ~]#
podman build -t srv.world/fedora-nginx:latest .

STEP 1: FROM fedora
STEP 2: MAINTAINER ServerWorld <admin@srv.world>
--> bcd6681d3b3
STEP 3: RUN dnf -y install nginx
.....
.....
Successfully tagged srv.world/fedora-nginx:latest
c2f266c51e583f0c09b47aedf4cc47d843c1b309ccd799091aa72ba85fd53d05

[root@dlp ~]#
podman images

REPOSITORY                         TAG     IMAGE ID      CREATED         SIZE
srv.world/fedora-nginx             latest  c2f266c51e58  20 seconds ago  425 MB
srv.world/fedora-httpd             latest  810bed9d1157  7 minutes ago   529 MB
registry.fedoraproject.org/fedora  latest  5f05951e2065  2 weeks ago     187 MB

# コンテナー起動

[root@dlp ~]#
podman run -d -p 80:80 srv.world/fedora-nginx

a1fbd8a8d83db23062a4452103c531c2ce811e2b5a5dea5018dcd921a081d44c

[root@dlp ~]#
podman ps

CONTAINER ID  IMAGE                          COMMAND               CREATED        STATUS            PORTS               NAMES
a1fbd8a8d83d  srv.world/fedora-nginx:latest  /usr/sbin/nginx -...  7 seconds ago  Up 8 seconds ago  0.0.0.0:80->80/tcp  jovial_curie

# アクセス確認

[root@dlp ~]#
curl localhost

Dockerfile Test on Nginx
# コンテナーネットワーク経由でもアクセス可

[root@dlp ~]#
podman inspect -l | grep \"IPAddress

            "IPAddress": "10.88.0.11",
                    "IPAddress": "10.88.0.11",

[root@dlp ~]#
curl 10.88.0.11

Dockerfile Test on Nginx
Docker ファイルでの記述フォーマットは [INSTRUCTION arguments] (指示 引数) の形となっており、INSTRUCTION には主に下記のような種類があります。なお、INSTRUCTION の必須項目は FROM のみで、その他は任意です。FROM が指定されていれば Docker ファイルは動作します。
INSTRUCTION 説明
FROM コンテナーのベースとするイメージを指定する
MAINTAINER コンテナーイメージの作成者を指定する
RUN コマンドの実行を指定する ⇒ イメージ作成時に実行される
CMD コマンドの実行を指定する ⇒ コンテナー実行時に実行される
[docker run] の際に実行されるが、[docker run] に引数があればそちらが優先される
ENTRYPOINT コマンドの実行を指定する ⇒ コンテナー実行時に実行される
「docker run」の際に実行されるが、[docker run] に引数があれば、ENTRYPOINT 指定コマンドに付加される
LABEL コンテナーイメージのラベルを指定する
EXPOSE リスンするポートを指定する
ENV 環境変数を指定する
ADD ファイル/ディレクトリの追加を指定する
COPY ファイル/ディレクトリの追加を指定する
ADD と異なる点は、リモートURL 指定不可、アーカイブファイルを自動で展開しない
VOLUME マウントポイントを指定する
USER 実行ユーザーを指定する
WORKDIR 作業ディレクトリを指定する

関連コンテンツ