docker?save與docker?export的區(qū)別
緣起
docker save和docker export都能導(dǎo)出鏡像包,咋看起來區(qū)別似乎不大。本文就針對這個問題,試圖搞清楚docker save和docker export的功能是什么?適用于什么應(yīng)用場景?
*注:用戶既可以使用 docker load 來導(dǎo)入鏡像存儲文件到本地鏡像庫,也可以使用 docker import 來導(dǎo)入一個容器快照到本地鏡像庫。這兩者的區(qū)別在于容器快照文件將丟棄所有的歷史記錄和元數(shù)據(jù)信息(即僅保存容器當(dāng)時的快照狀態(tài)),而鏡像存儲文件將保存完整記錄,體積也要大。此外,從容器快照文件導(dǎo)入時可以重新指定標(biāo)簽等元數(shù)據(jù)信息。
本文的測試的Docker版本如下,不保證所有版本的docker都能重現(xiàn)本文的結(jié)果。
>docker version Client: Version: 17.07.0-ce-rc1 API version: 1.31 Go version: go1.8.3 Git commit: 8c4be39 Built: Wed Jul 26 05:19:44 2017 OS/Arch: windows/amd64 Server: Version: 17.07.0-ce-rc1 API version: 1.31 (minimum version 1.12) Go version: go1.8.3 Git commit: 8c4be39 Built: Wed Jul 26 05:25:01 2017 OS/Arch: linux/amd64 Experimental: true
另外我是在Windows on bash里面操作docker,有些命令如ls
并不是windows命令,如果想要復(fù)現(xiàn)我的試驗,請換成相應(yīng)的windows命令。
docker save
docker的命令行接口設(shè)計得很優(yōu)雅,很多命令的幫助直接在后面加--help
就可以查看。
docker save的幫助如下:
>docker save --help Usage: docker save [OPTIONS] IMAGE [IMAGE...] Save one or more images to a tar archive (streamed to STDOUT by default) Options: --help Print usage -o, --output string Write to a file, instead of STDOUT
從命令行幫助可以看出,docker save是用來將一個或多個image打包保存的工具。
例如我們想將鏡像庫中的postgres和mongo打包,那么可以執(zhí)行:
docker save -o images.tar postgres:9.6 mongo:3.4
打包之后的images.tar
包含postgres:9.6
和mongo:3.4
這兩個鏡像。
雖然命令行參數(shù)要求指定image,實際上也可以對container進(jìn)行打包,例如:
>docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 3623943d369f postgres:9.6 "docker-entrypoint..." 3 hours ago Up 3 hours 5432/tcp postgres >docker save -o b.tar postgres >docker save -o c.tar postgres:9.6 >ls -al -rwxrwxrwx 1 root root 277886464 8月 26 14:40 b.tar -rwxrwxrwx 1 root root 277886464 8月 26 14:41 c.tar
通過以上命令可以看到,b.tar
和c.tar
是完全一模一樣的。這說明,docker save如果指定的是container,docker save將保存的是容器背后的image。
將打包后的鏡像載入進(jìn)來使用docker load,例如:
docker load -i images.tar
上述命令將會把postgres:9.6
和mongo:3.4
載入進(jìn)來,如果本地鏡像庫已經(jīng)存在這兩個鏡像,將會被覆蓋。
docker save的應(yīng)用場景是,如果你的應(yīng)用是使用docker-compose.yml編排的多個鏡像組合,但你要部署的客戶服務(wù)器并不能連外網(wǎng)。這時,你可以使用docker save將用到的鏡像打個包,然后拷貝到客戶服務(wù)器上使用docker load載入。
docker export
照例查看下docker export的幫助:
>docker export --help Usage: docker export [OPTIONS] CONTAINER Export a container's filesystem as a tar archive Options: --help Print usage -o, --output string Write to a file, instead of STDOUT
從幫助可以看出,docker export是用來將container的文件系統(tǒng)進(jìn)行打包的。例如:
docker export -o postgres-export.tar postgres
docker export需要指定container,不能像docker save那樣指定image或container都可以。
將打包的container載入進(jìn)來使用docker import,例如:
docker import postgres-export.tar postgres:latest
從上面的命令可以看出,docker import將container導(dǎo)入后會成為一個image,而不是恢復(fù)為一個container。
另外一點是,docker import可以指定IMAGE[:TAG],說明我們可以為鏡像指定新名稱。如果本地鏡像庫中已經(jīng)存在同名的鏡像,則原有鏡像的名稱將會被剝奪,賦給新的鏡像。原有鏡像將成為孤魂野鬼,只能通過IMAGE ID進(jìn)行操作。
docker export的應(yīng)用場景主要用來制作基礎(chǔ)鏡像,比如你從一個ubuntu鏡像啟動一個容器,然后安裝一些軟件和進(jìn)行一些設(shè)置后,使用docker export保存為一個基礎(chǔ)鏡像。然后,把這個鏡像分發(fā)給其他人使用,比如作為基礎(chǔ)的開發(fā)環(huán)境。
docker save和docker export的區(qū)別
總結(jié)一下docker save和docker export的區(qū)別:
- docker save保存的是鏡像(image),docker export保存的是容器(container);
- docker load用來載入鏡像包,docker import用來載入容器包,但兩者都會恢復(fù)為鏡像;
- docker load不能對載入的鏡像重命名,而docker import可以為鏡像指定新名稱。
腦洞
前面所講的內(nèi)容都是些基礎(chǔ)知識,相信各位讀者只要仔細(xì)看下官方文檔就能知曉。這一節(jié)我來講講文檔上沒有的東西。
docker load和docker import都可以將tar包導(dǎo)入為鏡像,我不禁腦洞一下,docker load能不能導(dǎo)入docker export的容器包,docker import能不能導(dǎo)入docker save的鏡像包呢?
以下開始試驗,準(zhǔn)備以下兩個文件:
>ls -al -rwxrwxrwx 1 root root 271760384 8月 26 12:15 postgres-export.tar -rwxrwxrwx 1 root root 398292480 8月 26 12:13 postgres-save.tar
其中postgres-export.tar
是通過docker export導(dǎo)出的容器包,postgres-save.tar
是通過docker save保存的鏡像包,兩者都是基于postgres:9.6
鏡像。從文件大小可以直觀的發(fā)現(xiàn),postgres-export.tar
顯然要比postgres-save.tar
小100多M。
現(xiàn)在試試docker load容器包postgres-export.tar
:
>docker load -i postgres-export.tar open /var/lib/docker/tmp/docker-import-082344818/bin/json: no such file or directory
顯然,docker load不能載入容器包。
那么,反過來,docker import載入鏡像包可不可以呢?
>docker import postgres-save.tar postgres sha256:8910feec1ee2fac8c152dbdd0aaab360ba0b833af5c3ad59fcd648b9a24d4838 >docker image ls REPOSITORY TAG IMAGE ID CREATED SIZE postgres latest 8910feec1ee2 2 minutes ago 398MB
WTF,竟然成功了?。。?/p>
莫慌,再試試啟動一個postgres容器:
>docker run postgres C:\Program Files\Docker\Docker\resources\bin\docker.exe: Error response from daemon: No command specified. See 'C:\Program Files\Docker\Docker\resources\bin\docker.exe run --help'.
雖然能夠成功地導(dǎo)入為一個鏡像,然而這個鏡像并不能使用。
要搞清楚到底是怎么回事,我們先看看鏡像包和容器包由什么區(qū)別:
從上面可以看出右邊的postgres-export.tar
的內(nèi)容是一個linux系統(tǒng)的文件目錄,猜測就是一個linux鏡像。而postgres-save.tar
里面到底是什么內(nèi)容呢?點開一個文件夾看看:
其實就是一個分層的文件系統(tǒng)。Docker鏡像實際上就是由這樣的一層層文件進(jìn)行疊加起來的,上層的文件會覆蓋下層的同名文件。如果將postgres-save.tar
中的各層文件合并到一起,基本就是postgres-export.tar
的內(nèi)容。由于postgres-save.tar
里面的各層文件會存在很多重復(fù)的文件,這也解釋了為什么postgres-save.tar
會比postgres-export.tar
大100多M。
docker load必須要載入的是一個分層文件系統(tǒng),而postgres-export.tar
并不具有這樣的結(jié)構(gòu),因此無法載入。
而docker import僅僅是將tar包里面的文件復(fù)制進(jìn)來,所以不管tar包里面的文件結(jié)構(gòu)是怎樣的,都可以載入進(jìn)來,所以能夠載入postgres-save.tar
。但postgres-save.tar
并不是一個有效的操作系統(tǒng)鏡像,因此當(dāng)我試圖以改鏡像啟動容器時,容器并不能啟動。
我們再來看看docker import的幫助:
Usage: docker import [OPTIONS] file|URL|- [REPOSITORY[:TAG]] Import the contents from a tarball to create a filesystem image Options: -c, --change list Apply Dockerfile instruction to the created image --help Print usage -m, --message string Set commit message for imported image
似乎和docker commit很像:
Usage: docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]] Create a new image from a container's changes Options: -a, --author string Author (e.g., "John Hannibal Smith <hannibal@a-team.com>") -c, --change list Apply Dockerfile instruction to the created image --help Print usage -m, --message string Commit message -p, --pause Pause container during commit (default true)
發(fā)現(xiàn)docker import和docker commit都有--change
和--message
選項。我們可以將docker import理解為將外部文件復(fù)制進(jìn)來形成只有一層文件系統(tǒng)的鏡像,而docker commit則是將當(dāng)前的改動提交為一層文件系統(tǒng),然后疊加到原有鏡像之上。
關(guān)于docker save和docker export的區(qū)別講得差不多,拜了個拜。
到此這篇關(guān)于docker save與docker export的區(qū)別的文章就介紹到這了,更多相關(guān)docker save與docker export內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Docker 網(wǎng)絡(luò)模式(四種)詳細(xì)介紹
這篇文章主要介紹了Docker 網(wǎng)絡(luò)模式詳細(xì)介紹的相關(guān)資料,這里提供了四種網(wǎng)絡(luò)模式的介紹,Docker 作為輕量級容器技術(shù),很多比較不錯的功能,網(wǎng)絡(luò)不是多好,這里就整理下,需要的朋友可以參考下2016-11-11Docker之自定義網(wǎng)絡(luò)實現(xiàn)
大家好,本篇文章主要講的是Docker之自定義網(wǎng)絡(luò)實現(xiàn),感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12docker覆蓋鏡像默認(rèn)命令之docker?entrypoint詳解
entrypoint命令就是覆蓋ENTRYPOINT命令的,本文給大家介紹了docker覆蓋鏡像默認(rèn)命令之docker?entrypoint的相關(guān)知識,需要的朋友可以參考下2023-10-10Docker制作MySQL鏡像并使用`/docker-entrypoint-initdb.d/`問題
這篇文章主要介紹了Docker制作MySQL鏡像并使用`/docker-entrypoint-initdb.d/`問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05Docker部署SQL Server 2019 Always On集群的實現(xiàn)
這篇文章主要介紹了Docker部署SQL Server 2019 Always On集群的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04關(guān)于CentOS 8.4離線安裝Docker包的問題
這篇文章主要介紹了CentOS 8.4離線安裝Docker,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09