存储

默认情况下,在容器内创建的所有文件都存储在一个可写的容器层上,该层位于只读且不可变的镜像层之上。

写入容器层的数据在容器被销毁时不会持久化。这意味着如果另一个进程需要这些数据,将其从容器中取出可能会很困难。

可写层对于每个容器都是唯一的。您无法轻松地将数据从可写层提取到主机或另一个容器。

存储挂载选项

Docker 支持以下类型的存储挂载,用于在容器的可写层之外存储数据:

无论您选择使用哪种类型的挂载,从容器内部来看,数据都是一样的。它在容器的文件系统中以目录或单个文件的形式呈现。

卷挂载

卷(Volumes)是由 Docker 守护进程管理的持久化存储机制。 即使使用它们的容器被删除,卷也会保留数据。卷数据存储在主机的文件系统上,但为了与卷中的数据进行交互,您必须将卷挂载到容器中。直接访问或与卷数据交互是不受支持的、未定义的行为,并可能导致卷或其数据以意外方式损坏。

卷非常适合性能关键的数据处理和长期存储需求。由于存储位置在守护主机上管理,卷提供与直接访问主机文件系统相同的原始文件性能。

挂载绑定

挂载卷在主机系统路径和容器之间建立直接链接,允许访问主机上存储的任何位置的文件或目录。由于它们不被 Docker 隔离,主机上的非 Docker 进程和容器进程可以同时修改已挂载的文件。

当您需要能够同时从容器和主机访问文件时,请使用绑定挂载。

tmpfs 挂载

tmpfs 挂载将文件直接存储在主机内存中,确保数据不会写入磁盘。这种存储是临时的:当容器停止或重启,或主机重启时,数据将丢失。tmpfs 挂载既不会在 Docker 主机上持久化数据,也不会在容器的文件系统中持久化数据。

这些挂载适用于需要临时、内存存储的场景,例如缓存中间数据、处理敏感信息(如凭据)或减少磁盘 I/O。仅当数据不需要在当前容器会话之后持久化时,才使用 tmpfs 挂载。

命名管道

命名管道 可用于 Docker 主机和容器之间的通信。常见用例是在容器内运行第三方工具,并使用命名管道连接到 Docker Engine API。

后续步骤

  • 了解更多关于
  • 了解更多关于 绑定挂载的信息。
  • 了解更多关于 tmpfs 挂载
  • 了解更多关于 存储驱动的信息,它们与绑定挂载或卷无关,但允许您将数据存储在容器的可写层中。