docker commit
読む時間の目安: 2 分
説明
コンテナーの変更に基づいて新たなイメージを生成します。
利用方法
$ docker commit [オプション] CONTAINER [REPOSITORY[:TAG]]
追加説明
コンテナー内のファイル変更や設定を、新たなイメージにコミットできると、役に立つことがあります。 これがあれば、コンテナーを対話型シェルにおいて起動しながらデバッグできたり、あるいは操作中のデータセットを別サーバーにエクスポートしたりできます。 一般的には Dockerfile にすべてを記述して、保守しやすい方法でイメージを管理していくことの方が望ましいことです。 適切なイメージ名とタグ をさらに参照してください。
コミット操作を行っても、コンテナー内のマウントボリュームのデータは含まれません。
イメージがコミットされる間、コミット対象のコンテナーとそのプロセスはデフォルトで停止します。
こうするのは、コミット処理の最中にデータ損傷の可能性を軽減するためです。
この動作が必要ない場合は--pause
オプションに false を設定してください。
--change
オプションを指定すると、イメージの生成時にDockerfile
命令をイメージに適用できます。
サポートされているDockerfile
命令は以下のとおりです。
CMD
|ENTRYPOINT
|ENV
|EXPOSE
|LABEL
|ONBUILD
|USER
|VOLUME
|WORKDIR
本コマンドの利用例については、以下に示す 利用例の節 を参照してください。
オプション
名前/省略形 | デフォルト | 説明 |
--author , -a |
作者名(たとえば "John Hannibal Smith <hannibal@a-team.com>")。 | |
--change , -c |
生成されたイメージに Dockerfile 命令を適用します。 | |
--message , -m |
コミットメッセージ。 | |
--pause , -p |
true |
コミット中はコンテナーを停止します。 |
利用例
コンテナーのコミット
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
c3f279d17e0a ubuntu:12.04 /bin/bash 7 days ago Up 25 hours desperate_dubinsky
197387f1b436 ubuntu:12.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
新たな設定を利用したコンテナーのコミット
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
c3f279d17e0a ubuntu:12.04 /bin/bash 7 days ago Up 25 hours desperate_dubinsky
197387f1b436 ubuntu:12.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]
新たなCMD
、EXPOSE
命令によるコンテナーのコミット
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
c3f279d17e0a ubuntu:12.04 /bin/bash 7 days ago Up 25 hours desperate_dubinsky
197387f1b436 ubuntu:12.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:12.04 /bin/bash 7 days ago Up 25 hours desperate_dubinsky
197387f1b436 ubuntu:12.04 /bin/bash 7 days ago Up 25 hours focused_hamilton
上位コマンド
コマンド | 説明 |
---|---|
docker | Docker CLI の基本コマンド |