docker container commit

内容説明コンテナーの変更内容からイメージを新たに生成します。
利用方法docker container commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
エイリアス
docker commit

内容説明

これはコンテナー内のファイルに対してのファイル変更や設定を、新たなイメージにコミットするために用います。 この機能を使うと、コンテナーのデバッグ作業を対話型シェルを実行して行うことができます。 または作業中のデータセットを別のコンテナーにエクスポートすることができます。

コミットには、マウントされているボリューム内のデータは含まれません。

イメージをコミットする際には、デフォルトではコンテナーおよびそのプロセスは一時停止します。 停止することで、コミット処理を行う過程におけるデータ破損の可能性を減らすものです。 この動作が不要である場合は --pause オプションに false を設定します。

--change オプションは、生成されるイメージに Dockerfile 命令を適用します。 サポートされる Dockerfile 命令は以下のものです。 CMD|ENTRYPOINT|ENV|EXPOSE|LABEL|ONBUILD|USER|VOLUME|WORKDIR

オプション

オプションデフォルト内容説明
-a, --author著者。 (たとえば John Hannibal Smith <hannibal@a-team.com>)
-c, --changeDockerfile 命令を生成イメージに適用します。
-m, --messageコミットメッセージ。
-p, --pausetrueコミット中にコンテナーを一時停止します。

利用例

コンテナーのコミット

$ docker ps

CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS              NAMES
c3f279d17e0a        ubuntu:24.04        /bin/bash           7 days ago          Up 25 hours                            desperate_dubinsky
197387f1b436        ubuntu:24.04        /bin/bash           7 days ago          Up 25 hours                            focused_hamilton

$ docker commit c3f279d17e0a  svendowideit/testimage:version3

f5283438590d

$ docker images

REPOSITORY                        TAG                 ID                  CREATED             SIZE
svendowideit/testimage            version3            f5283438590d        16 seconds ago      335.7 MB

新たな設定を使ったコンテナーのコミット (--change)

$ docker ps

CONTAINER ID       IMAGE               COMMAND             CREATED             STATUS              PORTS              NAMES
c3f279d17e0a       ubuntu:24.04        /bin/bash           7 days ago          Up 25 hours                            desperate_dubinsky
197387f1b436       ubuntu:24.04        /bin/bash           7 days ago          Up 25 hours                            focused_hamilton

$ docker inspect -f "{{ .Config.Env }}" c3f279d17e0a

[HOME=/ PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin]

$ docker commit --change "ENV DEBUG=true" c3f279d17e0a  svendowideit/testimage:version3

f5283438590d

$ docker inspect -f "{{ .Config.Env }}" f5283438590d

[HOME=/ PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin DEBUG=true]

新たな CMDEXPOSE 命令を使ったコンテナーのコミット

$ docker ps

CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS              NAMES
c3f279d17e0a        ubuntu:24.04        /bin/bash           7 days ago          Up 25 hours                            desperate_dubinsky
197387f1b436        ubuntu:24.04        /bin/bash           7 days ago          Up 25 hours                            focused_hamilton

$ docker commit --change='CMD ["apachectl", "-DFOREGROUND"]' -c "EXPOSE 80" c3f279d17e0a  svendowideit/testimage:version4

f5283438590d

$ docker run -d svendowideit/testimage:version4

89373736e2e7f00bc149bd783073ac43d0507da250e999f3f1036e0db60817c0

$ docker ps

CONTAINER ID        IMAGE               COMMAND                 CREATED             STATUS              PORTS              NAMES
89373736e2e7        testimage:version4  "apachectl -DFOREGROU"  3 seconds ago       Up 2 seconds        80/tcp             distracted_fermat
c3f279d17e0a        ubuntu:24.04        /bin/bash               7 days ago          Up 25 hours                            desperate_dubinsky
197387f1b436        ubuntu:24.04        /bin/bash               7 days ago          Up 25 hours                            focused_hamilton