我设法找到了目录下的容器/var/lib/docker/containers
,但找不到图像。
下的目录和文件是/var/lib/docker
什么?
目录的内容/var/lib/docker
因Docker 用于存储的驱动程序而异。
默认情况下,这将是aufs
但可以回退到overlay
, overlay2
, btrfs
,devicemapper
或zfs
取决于您的内核支持。在大多数地方,这将是aufs
,但RedHat 与devicemapper
.
您可以使用Docker 守护程序的-s
or--storage-driver=
选项手动设置存储驱动程序。
/var/lib/docker/{driver-name}
将包含图像内容的驱动程序特定存储。/var/lib/docker/graph/<id>
json
现在只在和layersize
文件中包含有关图像的元数据。在这种情况下aufs
:
/var/lib/docker/aufs/diff/<id>
具有图像的文件内容。/var/lib/docker/repositories-aufs
是一个包含本地图像信息的 JSON 文件。这可以用命令查看docker images
。在这种情况下devicemapper
:
/var/lib/docker/devicemapper/devicemapper/data
存储图像/var/lib/docker/devicemapper/devicemapper/metadata
元数据使用 Docker for Mac 应用程序时,容器似乎存储在位于以下位置的 VM 中:
~/Library/Containers/com.docker.docker/Data/com.docker.driver.amd64-linux/Docker.qcow2
更新(由mmorin提供):
截至 2019 年 1 月 15 日,似乎只有这个文件:
~/Library/Containers/com.docker.docker/Data/vms/0/Docker.raw
包含 Docker 磁盘以及其中的所有图像和容器。
实际上,Docker 镜像存储在两个文件中,如以下命令所示
$ docker info
数据文件:
/var/lib/docker/devicemapper/devicemapper/data
元数据文件:
/var/lib/docker/devicemapper/devicemapper/metadata
这是以前的做法,现在已经改变了。自 2019 年起忽略此答案
在 Mac OS X 或 Windows 的特殊情况下,使用 boot2docker,您的 Docker 映像存储在由 boot2docker 管理的 VirtualBox VM 中。
此 VM 将存储在 VirtualBox 映像的正常位置:
操作系统:~/VirtualBox VMs/boot2docker-vm
视窗:%USERPROFILE%/VirtualBox VMs/boot2docker-vm
您可以通过运行来重置它(警告:这将破坏您迄今为止构建和下载的所有图像):
boot2docker down
boot2docker destroy
boot2docker init
boot2docker up
如果您在构建/调试构建时保留大量中间图像而没有有用的 --rm 选项,这将特别有用,我在此引用它们以供参考:使用:
docker build -t webapp --rm=true --force-rm=true .
代替:
docker build -t webapp .
图像存储在/var/lib/docker/graph/<id>/layer
.
请注意,图像只是与父图像的差异。父 ID 与图像的元数据一起存储/var/lib/docker/graph/<id>/json
。
当你docker run
一个形象。AUFS 会将所有层“合并”到一个可用的文件系统中。
在新发布的使用 Hyper-V 的“Docker for Windows”上,数据位于 Docker 虚拟硬盘中:
C:\Users\Public\Documents\Hyper-V\Virtual hard disks\MobyLinuxVM.vhdx
您还可以打开“Hyper-V 管理器”以访问 Docker / MobyLinuxVM。
在 Ubuntu 上,您可以“玩”运行图像
sudo baobab /var/lib/docker
实际上,图像存储在/var/lib/docker/aufs/diff
对于使用 Docker 工具箱(使用 docker-machine)的人,有关 Mac OS X 上 boot2docker 的答案无效。docker-machine VM 被称为“默认”,它存在于/Users/<username>/.docker/machine/machines/default/
目录中。
如果您将 Docker 用于 MAC(不是boot2docker
),那么位置是/Users/<</>UserName></>/Library/Containers/com.docker.docker/Data/
在Docker for Windows(本机 Windows)中,默认容器存储位于:
> docker info
...
Docker Root Dir: C:\ProgramData\Docker
...
sudo docker info | grep -e "Root Dir"
如此处所回答,如果您使用的是 Mac,它位于
/Users/MyUserName/Library/Containers/com.docker.docker/Data/com.docker.driver.amd64-linux/Docker.qcow2
扩展 Tristan 的答案,在带有 Hyper-V 的 Windows 中,您可以使用matthuisman中的以下步骤移动图像:
在 Windows 10 中,
- 停止码头工人等
- 在任务栏搜索框中输入“Hyper-V Manager”并运行它。
- 在左侧窗格中选择您的 PC(我的称为 DESKTOP-CBP**)
- 右键单击正确的虚拟机(我的称为 MobyLinuxVM)
- 选择“关闭”(如果它正在运行)
- 再次右键单击它并选择“移动”
- 按照提示操作
使用docker info
命令显示系统范围的信息,位置可能会有所不同。
根据使用的存储驱动程序,可以显示附加信息,例如池名称、数据文件、元数据文件、使用的数据空间、总数据空间、使用的元数据空间和总元数据空间。
数据文件是存储图像的位置,而元数据文件是存储有关这些图像的元数据的位置。
/var/lib/docker
第一次运行时,Docker 会从挂载的卷上的可用空间中分配一定数量的数据空间和元数据空间。
这是 Ubuntu 上的示例(检查Root Dir):
$ docker info
...
Server Version: 18.06.1-ce
Storage Driver: aufs
Root Dir: /var/snap/docker/common/var-lib-docker/aufs
...
Docker Root Dir: /var/snap/docker/common/var-lib-docker
...
这是 Travis CI 上的示例(请参阅Docker Root Dir):
$ docker info
Server Version: 17.09.0-ce
Storage Driver: overlay2
Backing Filesystem: extfs
...
Docker Root Dir: /var/lib/docker
...
您可以使用--format
参数将该信息提取到单个文件中,例如
$ docker info --format '{{.DriverStatus}}'
[[Root Dir /var/snap/docker/common/var-lib-docker/aufs] [Backing Filesystem extfs] [Dirs 265] [Dirperm1 Supported true]]
或者:
$ docker info --format '{{json .DriverStatus}}'
[["Root Dir","/var/snap/docker/common/var-lib-docker/aufs"],["Backing Filesystem","extfs"],["Dirs","265"],["Dirperm1 Supported","true"]]
使用docker inspect container_id
MergedDir 下的查找文件夹
# example.
"MergedDir": "/var/lib/docker/overlay2/f40cc2ea8912ec3b32deeef5a1542a132f6e918acb/merged
如果您记住 Docker 仍在 VM 中运行,则系统路径是相对于 VM 而不是来自 Mac Osx 系统。正如它所说,所有内容都包含在 VM 文件中:
/Users/MyUserName/Library/Containers/com.docker.docker/Data/com.docker.driver.amd64-linux/Docker.qcow2
尝试使用此卷选项和 ls 命令运行 Alpine 映像,您可以列出 VM 主机:
docker run --rm -it -v /:/vm-root alpine:edge ls -l /vm-root
在此之后尝试:
docker run --rm -it -v /:/vm-root alpine:edge ls -l /vm-root/var/lib/docker
现在,您可以列出 VM 主机中的 docker 文件夹
我在 Mac OSX 上使用 Docker 的 boot2docker,所以图像存储在/Users/<USERNAME>/VirtualBox VMs/boot2docker-vm/boot2docker-vm.vmdk
.
我只能为 Ubuntu 用户回答这个问题:
运行命令可以找到docker的根目录docker info
Docker 目录将在这一行给出:“ Docker Root Dir: /var/lib/docker
”
关于 docker 镜像,它们存储在 docker 目录中:
/var/lib/docker/aufs/diff/
请记住,这些东西在所有版本的 docker 中都不相同。目前,我使用的是 1.12.3。
检查 docker 文件夹/var/lib
图像存储在以下位置:
/var/lib/docker/image/overlay2/imagedb/content
在 Docker for Windows 中,日志位于:%USERPROFILE%\AppData\Local\Docker
环境噪声
操作系统:fedora 29 x86_64 workstation
码头工人:
[user@localhost ~]$ docker --version
Docker version 19.03.5, build 633a0ea838
图片信息:"DockerVersion": "18.09.7"
图像应/var/lib/docker/overlay2
默认存储。
我的例子
显示图像:
[user@localhost ~]$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
neo4j latest 8ed7463b8476 12 months ago 548MB
hello-world latest fce289e99eb9 2 years ago 1.84kB
图像大小为 548M。
查看图片信息8ed7463b8476
。
[user@localhost ~]$ docker image inspect 8ed7463b8476
... ... ... ...
"DockerVersion": "18.09.7",
... ... ... ...
"GraphDriver": {
"Data": {
"LowerDir": "/var/lib/docker/overlay2
/66dc24704d7ea5f1a5dee0bf4a5297cb78bcbd0d4b36206b8cca62cd4de7f2b1/diff:
/var/lib/docker/overlay2
/5ab91cf721359d43d01038233d397fd9ed1c4b3857c0c7d9a2dd7f2ac5eccad0/diff:
/var/lib/docker/overlay2
/e82fdf7ee3e37db0a11d9ca309245ae852425d24d6f5d3313dcf604cdddb397b/diff:
/var/lib/docker/overlay2
/9394543085d467010d0468fffb388e5616a89e2cf16c1c2b7b31aee4e542ae69/diff:
/var/lib/docker/overlay2
/c7c7a16e3dbaeea1a3a3b0bbca39f34f08f6b8ab15d753e6e68f9851c80d95b4/diff:
/var/lib/docker/overlay2
/3b470afdf8939b45159f3171f0bef2a27085b4b980e09f0c666fbdc58b944d97/diff:
/var/lib/docker/overlay2
/463ba63f79eb6b2f5466e7b71041bc346a8e9c4ebddd34d23422c719824a2340/diff",
... ... ... ...
让我们看看这些文件夹的大小。
[user@localhost ~]$ sudo du -sh /var/lib/docker/overlay2/66dc24704d7ea5f1a5dee0bf4a5297cb78bcbd0d4b36206b8cca62cd4de7f2b1
141M /var/lib/docker/overlay2/66dc24704d7ea5f1a5dee0bf4a5297cb78bcbd0d4b36206b8cca62cd4de7f2b1
[user@localhost ~]$ sudo du -sh /var/lib/docker/overlay2/5ab91cf721359d43d01038233d397fd9ed1c4b3857c0c7d9a2dd7f2ac5eccad0/
28K /var/lib/docker/overlay2/5ab91cf721359d43d01038233d397fd9ed1c4b3857c0c7d9a2dd7f2ac5eccad0/
[user@localhost ~]$ sudo du -sh /var/lib/docker/overlay2/e82fdf7ee3e37db0a11d9ca309245ae852425d24d6f5d3313dcf604cdddb397b/
100K /var/lib/docker/overlay2/e82fdf7ee3e37db0a11d9ca309245ae852425d24d6f5d3313dcf604cdddb397b/
[user@localhost ~]$ sudo du -sh /var/lib/docker/overlay2/9394543085d467010d0468fffb388e5616a89e2cf16c1c2b7b31aee4e542ae69/
310M /var/lib/docker/overlay2/9394543085d467010d0468fffb388e5616a89e2cf16c1c2b7b31aee4e542ae69/
[user@localhost ~]$ sudo du -sh /var/lib/docker/overlay2/c7c7a16e3dbaeea1a3a3b0bbca39f34f08f6b8ab15d753e6e68f9851c80d95b4/
36K /var/lib/docker/overlay2/c7c7a16e3dbaeea1a3a3b0bbca39f34f08f6b8ab15d753e6e68f9851c80d95b4/
[user@localhost ~]$ sudo du -sh /var/lib/docker/overlay2/3b470afdf8939b45159f3171f0bef2a27085b4b980e09f0c666fbdc58b944d97/
9.5M /var/lib/docker/overlay2/3b470afdf8939b45159f3171f0bef2a27085b4b980e09f0c666fbdc58b944d97/
[user@localhost ~]$ sudo du -sh /var/lib/docker/overlay2/463ba63f79eb6b2f5466e7b71041bc346a8e9c4ebddd34d23422c719824a2340/
76M /var/lib/docker/overlay2/463ba63f79eb6b2f5466e7b71041bc346a8e9c4ebddd34d23422c719824a2340/
我们可以看到接近548M的大小。
我们还可以将图像保存到输出文件。
[user@localhost ~]$ docker save -o neo4j.image.tar 8ed7463b8476
[user@localhost ~]$ du -sh neo4j.image.tar
528M neo4j.image.tar
我们可以提取包文件并检查包中文件的大小。
[user@localhost neo4j.image]$ du -sh *
16K 2f0dd5fb60a940719a3e781133611cc64c2acded03bd47e04b0997fd0c1dae50
8.7M 73819037a38eabeb7c622533e4058c84f5ff106475a1aba78a278f8b36c172f7
309M 8d31d715b324a2ae3ccb1577e981d492f40e34db6371f0858da925ef02b5762e
12K 8ed7463b84760f09b1b86a732ee6f295baaadffe72ce4fdb7ad306fe5e096bbb.json
36K 966e726ff1d9be9dca68014cda6f1ecf974365c553b82ea3834fff5d73ea593e
70M a32776b9621e916e8714389b1037bf47253a2d3d1c806ad515623d2150c92485
60K d82868a318b95466f213136f81cd7258518744da72f46ca51b04b35f2351f46a
16K e62169d79fab44bebb0a455b01af5f636bace7673a1d38fc092daad77d51cd0e
141M fe8014622f7933e178b9005deffda3eb4828703eb7eca93b5485232930e3916b
4.0K manifest.json
我们还可以将文件夹存档,/var/lib/docker/overlay2/
以将包的大小与图像文件进行比较。尺寸也接近图像尺寸。
更多有用的读物:
环境:Windows 10 Pro,docker desktop 2.0.3.0 edge
右键单击系统托盘中的泊坞窗图标,选择设置 - 高级:
磁盘映像位置(可通过浏览器编辑):
C:\Users\Public\Documents\Hyper-V\Virtual Hard Disks\DockerDesktop.vhdx
(它在那里 - Documents 目录被隐藏)
在 Fedora 上,Docker 使用LVM进行存储(如果可用)。在我的系统docker info
上显示:
Storage Driver: devicemapper
Pool Name: vg01-docker--pool
Pool Blocksize: 524.3 kB
Base Device Size: 10.74 GB
Backing Filesystem: xfs
Data file:
Metadata file:
Data Space Used: 9.622 GB
...
在这种情况下,要增加存储空间,您将不得不使用 LVM 命令行工具或兼容的分区管理器,如blivet。
在 Windows 2016 中,docker (DockerMsftProvider) 使用 docker root 下的文件夹“windowsfilter”
>docker info
...
Storage Driver: windowsfilter
...
Docker Root Dir: C:\ProgramData\docker
...
它使用 docker root 下的“tmp”文件夹下载文件,并将下载的文件解压缩到“windowsfilter”文件夹后删除文件。
在 Debian 不稳定/Sid 上,
docker info
查找系统范围的信息。
图像存储在/var/lib/docker/image/overlay2/imagedb/content
和
容器存放在/var/lib/docker/containers
码头工人版本18.06.0-ce
,API版本1.38
我无法使用上述答案在 Docker 版本 18.09 上解决问题并再次尝试。
对我来说唯一实际的解决方案是使用此docker-compose.yml
配置:
version: '3.7'
...
services:
demo-service:
volumes:
- data-volume:/var/tmp/container-volume
volumes:
data-volume:
driver: local
driver_opts:
type: none
o: bind
device: /tmp/host-volume
启动后,docker-compose up
我终于/tmp/host-volume
从容器中共享为可写卷的 macos:
> docker exec -it 1234 /bin/bash
bash-4.4$ df
Filesystem 1K-blocks Used Available Use% Mounted on
...
osxfs 488347692 464780044 21836472 96% /var/tmp/container-volume
希望这对其他人也有帮助。
如果有人出于脚本目的需要它,这里有一个单行解决方案。
在启用 PCRE 的 POSIX shell 中grep
,尝试:
DOCKER_ROOT_DIR="$(docker info 2>&1 | grep -oP '(?<=^Docker Root Dir: ).*')"
在 PowerShell 中:
$DOCKER_ROOT_DIR="$(docker info 2>&1 | foreach {if($_ -match "Docker Root Dir"){$_.TrimStart("Docker Root Dir: ")}})"
请注意,在 Windows 10(截至10.0.18999.1
)上,在默认配置中,它会返回:
C:\ProgramData\Docker
在“Windows 容器”模式下/var/lib/docker
, 在“Linux 容器”模式下图像存储在里面/var/lib/docker
,然后在适用的storage driver
目录下。
正在使用的存储驱动程序可以通过执行docker info
命令来确定。
在 2021 年的 macOS 上,唯一可能的解决方案是使用 bash 访问 Docker VM,然后查看它的本地结构:
docker run -ti --privileged --pid=host debian nsenter -t 1 -m -u -n -i sh
cd /var/lib/docker/
别客气!