Fedora 32
Sponsored Link

Buildah : インストール
2020/05/11
 
コンテナーイメージ作成ツール Buildah をインストールします。
OCI (Open Container Initiative) イメージ フォーマットに準拠したコンテナーイメージを作成可能 且つ デーモン不要で利用できます。
[1] Buildah をインストールします。
[root@dlp ~]#
dnf -y install buildah
[2] Buildah の基本操作です。
イメージからワーキングコンテナーを新規作成する。
# [fedora] イメージからワーキングコンテナー作成

[root@dlp ~]#
buildah from fedora

Getting image source signatures
Copying blob 3088721d7dbf0.0b / 0.0b
Copying config d81c91deec done
Writing manifest to image destination
Storing signatures
fedora-working-container

# コンテナーリスト

[root@dlp ~]#
buildah containers

CONTAINER ID  BUILDER  IMAGE ID     IMAGE NAME                       CONTAINER NAME
3b142346cd14     *     d81c91deec0d registry.fedoraproject.org/fe... fedora-working-container

# コンテナーイメージリスト

[root@dlp ~]#
buildah images

REPOSITORY                          TAG      IMAGE ID       CREATED       SIZE
registry.fedoraproject.org/fedora   latest   d81c91deec0d   11 days ago   208 MB

# コンテナーイメージは podman からも使用可

[root@dlp ~]#
podman images

REPOSITORY                          TAG      IMAGE ID       CREATED       SIZE
registry.fedoraproject.org/fedora   latest   d81c91deec0d   11 days ago   208 MB
[3] ワーキングコンテナーを操作する。
# シェル変数に格納可能

[root@dlp ~]#
container=$(buildah from fedora)

[root@dlp ~]#
echo $container

fedora-working-container-1
# コンテナーから各種コマンド実行可能

[root@dlp ~]#
buildah run $container echo "Hello Buildah World"

Hello Buildah World
[root@dlp ~]#
buildah run $container bash

[root@0ffef2df688f /]#
dnf install python3

[root@0ffef2df688f /]#
[root@dlp ~]#
buildah run $container whereis python3

python3: /usr/bin/python3 /usr/bin/python3.8 /usr/lib/python3.8 /usr/lib64/python3.8 /usr/include/python3.8
[4] ワーキングコンテナー内へファイルをコピーする。
[root@dlp ~]#
echo "buildah test" > buildah.txt

[root@dlp ~]#
buildah copy $container buildah.txt /tmp/buildah.txt

c1172b94183d8ad1541c3d96e54e11a21c6b8508a0ead5d8b902b2e035ba6372
[root@dlp ~]#
buildah run $container cat /tmp/buildah.txt

buildah test
[5] ワーキングコンテナーのファイルシステムをマウントする。
[root@dlp ~]#
buildah mount $container

/var/lib/containers/storage/overlay/525ee63daa36f2b9d04d4e21ec16091c91c0ccad1f87fa2bfb1583afd70abd48/merged
[root@dlp ~]#
ll /var/lib/containers/storage/overlay/525ee63daa36f2b9d04d4e21ec16091c91c0ccad1f87fa2bfb1583afd70abd48/merged

total 0
lrwxrwxrwx.  1 root root   7 Jan 28 13:30 bin -> usr/bin
dr-xr-xr-x.  2 root root   6 Jan 28 13:30 boot
drwxr-xr-x.  2 root root   6 Apr 29 02:47 dev
drwxr-xr-x.  1 root root  38 Apr 29 02:47 etc
drwxr-xr-x.  2 root root   6 Jan 28 13:30 home
.....
.....

# アンマウント

[root@dlp ~]#
buildah umount $container

0ffef2df688fb628c7fcfaf61a0f8962f2a44abf82112ff413b51f5b9d788b2c
[6] ワーキングコンテナーからイメージを作成する。
[root@dlp ~]#
buildah commit $container my-fedora:latest

Getting image source signatures
Copying blob a4c0fa2b217d skipped: already exists
Copying blob c5baae57ea51 done
Copying config c3e6a732a5 done
Writing manifest to image destination
Storing signatures
c3e6a732a5c5577d6999b3b564c3d0811f09601afd998f78298ae721d8d12908
[root@dlp ~]#
buildah images

REPOSITORY                          TAG      IMAGE ID       CREATED          SIZE
localhost/my-fedora                 latest   c3e6a732a5c5   21 seconds ago   392 MB
registry.fedoraproject.org/fedora   latest   d81c91deec0d   11 days ago      208 MB

# 作成したコンテナーイメージは podman からも利用可

[root@dlp ~]#
podman run localhost/my-fedora echo my fedora

my fedora
[7] コンテナーイメージを指定の Registry へ Push する。
[root@dlp ~]#
buildah images

REPOSITORY                          TAG      IMAGE ID       CREATED          SIZE
localhost/my-fedora                 latest   c3e6a732a5c5   48 seconds ago   392 MB
registry.fedoraproject.org/fedora   latest   d81c91deec0d   11 days ago      208 MB

# [localhost/my-fedora] イメージを [node01.srv.world:5000] へ Push する

# Push 先の registry が SSL/TLS 未対応の場合は [--tls-verify=false] オプション付加が必要

[root@dlp ~]#
buildah push --tls-verify=false localhost/my-fedora node01.srv.world:5000/my-fedora

Getting image source signatures
Copying blob c5baae57ea51 done
Copying blob a4c0fa2b217d done
Copying config c3e6a732a5 done
Writing manifest to image destination
Storing signatures

[root@dlp ~]#
curl node01.srv.world:5000/v2/_catalog

{"repositories":["my-fedora","nginx_server"]}
# 他の任意のノードから Pull 可能

[root@node01 ~]#
podman pull --tls-verify=false node01.srv.world:5000/my-fedora

[root@node01 ~]#
podman images

REPOSITORY                        TAG      IMAGE ID       CREATED          SIZE
node01.srv.world:5000/my-fedora   latest   0a3ba69587a4   19 minutes ago   263 MB
docker.io/library/registry          2        708bc6af7e5e   3 months ago   26.3 MB
関連コンテンツ