/var/lib/docker/目录解析

/var/lib/docker/ 是 Docker 引擎在 Linux 系统中默认存储 Docker 数据的目录,它包含了 Docker 引擎的运行时数据、容器镜像、容器卷等相关文件。

下面是 /var/lib/docker/ 目录中的一些重要子目录及其作用的简要解析:

/var/lib/docker/containers/

  • :存储运行中的容器的数据,每个容器对应一个目录,包含容器的元数据、文件系统等信息。
    1 /var/lib/docker/containers 目录是 Docker 存储容器相关数据的默认位置。在 Docker 中,每个容器都会被视为一个独立的实体,其相关数据(如容器的配置信息、状态信息、日志等)都会存储在 /var/lib/docker/containers 目录下的对应目录中。

2 具体而言,/var/lib/docker/containers 目录下的每个子目录都对应一个 Docker 容器,子目录的名称通常是由容器的 ID 组成的一串字符,例如:

/var/lib/docker/containers/
├── 8a72c280f22b7465e5d26a532a8c14071c88f50d9e0c0498738e24c22181fd33
├── 234b05667f6c0487a7631263d9cde6b8cd23345b2e95640f61fd84d2a2a1aa34
├── ...
└── f82b3c649f56a94da26d3dcee058de1b7ad160773fc4a4e14e4fc477501c5b5d

这些子目录中包含了与相应容器相关的文件和目录,其中一些重要的文件和目录包括:

  • config.v2.json:包含容器的配置信息,如容器的名称、镜像、挂载卷、环境变量等。
  • hostname:包含容器的主机名。
  • resolv.conf:包含容器的 DNS 配置信息。
  • checkpoints:用于存储容器的检查点(Checkpoint)文件。
  • logs:用于存储容器的日志文件。
  • mounts:包含容器的挂载卷信息。
  • state:包含容器的状态信息,如容器的运行状态、进程信息等。

/var/lib/docker/image/

  • :存储容器镜像的数据,每个容器镜像对应一个目录,包含容器镜像的元数据、图层等信息。
    /var/lib/docker/image/ 目录是 Docker 存储镜像相关数据的默认位置。在 Docker 中,镜像是用于创建容器的模板,包含了一个完整的应用程序和其所有依赖的文件系统快照。镜像的相关数据,例如镜像文件、元数据、缓存等,都会存储在 /var/lib/docker/image/ 目录下的对应目录中。

具体而言,/var/lib/docker/image/ 目录下包含了以下几个子目录:

  • aufs:如果使用 AUFS 存储驱动(在旧版本的 Docker 中),则镜像的文件系统层会以 AUFS 格式存储在这个目录下的子目录中。每个子目录的名称都是由一个唯一的 ID 组成,对应着一个镜像的文件系统层。

  • overlay2:如果使用 Overlay2 存储驱动(在较新版本的 Docker 中),则镜像的文件系统层会以 Overlay2 格式存储在这个目录下的子目录中。每个子目录的名称都是由一个唯一的 ID 组成,对应着一个镜像的文件系统层。

  • overlay:如果使用 Overlay 存储驱动(在一些较旧的 Docker 版本中),则镜像的文件系统层会以 Overlay 格式存储在这个目录下的子目录中。每个子目录的名称都是由一个唯一的 ID 组成,对应着一个镜像的文件系统层。

  • image.db:这是一个 SQLite 数据库文件,用于存储 Docker 镜像的元数据信息,例如镜像的名称、标签、大小、创建时间等。

  • image/:这是一个软链接(symlink),指向存储镜像文件的实际目录(如 aufs、overlay2、overlay 中的其中一个)。这个软链接的目的是为了向后兼容,以支持不同的存储驱动。
    需要注意的是,/var/lib/docker/image/ 目录下的数据都是 Docker 引擎自动管理和维护的,对这些数据进行手动修改可能会导致镜像无法正常使用或数据丢失。因此,不推荐直接对 /var/lib/docker/image/ 目录下的文件和目录进行修改,除非你对 Docker 引擎和镜像的运行原理非常了解,并且有充分的备份和恢复措施。

  • /var/lib/docker/volumes/:存储容器卷的数据,每个容器卷对应一个目录,包含容器卷的数据。
    /var/lib/docker/volumes/ 目录是 Docker 用于存储容器卷数据的默认位置。在 Docker 中,容器卷是一种用于持久化存储容器数据的机制,可以在容器之间共享和重用数据。/var/lib/docker/volumes/ 目录下包含了 Docker 卷相关的数据和元数据。

具体而言,/var/lib/docker/volumes/ 目录下可能包含以下一些文件和目录:

<volume-id>/:每个通过 Docker 创建的卷都会在这个目录下创建一个子目录,子目录的名称是由一个唯一的 ID 组成,对应着一个卷。这个子目录下包含了该卷的实际数据。例如,如果你在 Docker 中创建了一个名为 my_volume 的卷,那么在 /var/lib/docker/volumes/ 目录下会创建一个名为 <volume-id> 的子目录,里面存储了 my_volume 卷的实际数据。
vfs/:如果你在 Docker 中使用了 VFS 存储驱动(如在旧版 Docker 中使用的 "vfs" 驱动),那么这个目录下会存在与 VFS 相关的配置文件和状态信息。
需要注意的是,/var/lib/docker/volumes/ 目录下的数据都是 Docker 引擎自动管理和维护的,对这些数据进行手动修改可能会导致容器卷无法正常使用或数据丢失。因此,不推荐直接对 /var/lib/docker/volumes/ 目录下的文件和目录进行修改,除非你对 Docker 引擎和存储驱动的运行原理非常了解,并且有充分的备份和恢复措施。

/var/lib/docker/network/:

存储 Docker 网络的数据,包含 Docker 网络的配置和状态信息。
/var/lib/docker/network/ 目录是 Docker 存储网络相关数据的默认位置。在 Docker 中,网络是用于容器之间通信的关键组件,负责实现容器之间的通讯和连接。/var/lib/docker/network/ 目录下包含了 Docker 网络驱动所使用的配置文件、状态信息等。

具体而言,/var/lib/docker/network/ 目录下可能包含以下一些文件和目录:

  • bridge/:如果使用 Docker 的默认网络驱动 "bridge",则在这个目录下会存在与 "bridge" 网络相关的配置文件和状态信息。例如,每个通过 Docker 创建的 "bridge" 网络都会在这个目录下创建一个子目录,子目录的名称是由一个唯一的 ID 组成,对应着一个 "bridge" 网络。这个子目录下可能包含 config.v2.json 文件,用于存储 "bridge" 网络的配置信息,以及 networkSettings.json 文件,用于存储 "bridge" 网络的状态信息。
  • overlay/:如果使用 Overlay 网络驱动,那么在这个目录下会存在与 Overlay 网络相关的配置文件和状态信息。类似于 "bridge" 网络,每个通过 Docker 创建的 Overlay 网络都会在这个目录下创建一个子目录,子目录的名称也是由一个唯一的 ID 组成,对应着一个 Overlay 网络。这个子目录下可能包含 config.v2.json 文件,用于存储 Overlay 网络的配置信息,以及 networkSettings.json 文件,用于存储 Overlay 网络的状态信息。
  • plugins/:如果使用第三方的网络驱动插件,那么这个目录下可能会包含与这些插件相关的配置文件和状态信息。每个网络驱动插件都可能有自己的目录,用于存储其配置信息和状态信息。
    需要注意的是,/var/lib/docker/network/ 目录下的数据都是 Docker 引擎自动管理和维护的,对这些数据进行手动修改可能会导致网络无法正常使用或数据丢失。因此,不推荐直接对 /var/lib/docker/network/ 目录下的文件和目录进行修改,除非你对 Docker 引擎和网络驱动插件的运行原理非常了解,并且有充分的备份和恢复措施。

/var/lib/docker/overlay2

/var/lib/docker/overlay2 目录是 Docker 存储驱动程序之一 Overlay2 的默认存储目录,用于保存 Docker 容器镜像和容器数据。Overlay2 是一个基于内核的图层存储驱动程序,可以通过将多个只读层叠加到单个可写层来创建 Docker 容器。Overlay2 驱动程序使用了基于 inode 的存储模型,它将不同的图层都挂载到相同的文件系统目录下,同时使用不同的命名空间来进行隔离。
在 /var/lib/docker/overlay2 目录下,每个容器都对应一个文件夹,文件夹的名称是由两个长随机字符串组成的,每个字符串对应一个不同的命名空间。其中一个字符串对应于 Overlay2 驱动程序的命名空间,它用于标识这个容器的图层;另一个字符串对应于挂载点的命名空间,用于在宿主机文件系统中创建一个目录,用于挂载这个容器的可写层。
每个容器的文件夹中包含多个子目录,其中最重要的是 diff 目录,它用于存储容器的可写层。当 Docker 容器需要修改文件时,Overlay2 驱动程序会将这些修改记录在 diff 目录下的文件中。除了 diff 目录,每个容器的文件夹中还包含 merged 目录、lowerdir 目录和 upperdir 目录,用于存储容器的只读层和可写层。
具体来说,当 Docker 运行容器时,它会在 /var/lib/docker/overlay2 目录下为容器创建一个唯一的文件夹,其中包含了容器的文件系统的层级结构。该文件夹的名称以 l 开头,后跟 64 个字符的十六进制字符串,这个字符串是该容器的唯一 ID,例如:

/var/lib/docker/overlay2/l4j4t4c3k3ck0ec13c4a5798d274b16523e86029292bfb9bb9c4a4a4c3d0e4b4

在这个目录中,Overlay2 存储了容器的所有文件系统层。当容器启动时,Docker 会将这些层级结构组合在一起,形成容器的完整文件系统,使其看起来像是一个完整的文件系统,而实际上是由多个层级结构组合而成的。
此外,该目录下还包含了一些元数据,用于管理这些层和容器。例如,该目录下的 diff 子目录存储了容器文件系统的写入层,而 merged 子目录是通过将不同层级的文件系统层级结构合并而成的,work 子目录用于 Overlay2 内部操作。

  • /var/lib/docker/tmp/:存储 Docker 引擎的临时数据,如构建镜像时的临时文件等。

  • /var/lib/docker/swarm/:存储 Docker Swarm 模式下的数据,包括 Swarm 集群的配置和状态信息。

  • /var/lib/docker/trust/:存储 Docker 引擎的签名和证书数据,用于 Docker 镜像的安全性验证。

这只是 /var/lib/docker/ 目录中的一些常见子目录,实际上还可能包含其他目录和文件,具体的目录结构和文件内容可能因 Docker 版本、配置和使用方式而有所不同。在进行 Docker 相关操作时,需要小心处理这些目录和文件,以确保 Docker 数据的完整性和安全性。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容