一、什么是数据卷?

数据卷是一个可供一个或多个容器使用的特殊目录,它绕过 UFS,可以提供很多有用的特性:

  • 数据卷可以在容器之间共享和重用
  • 对数据卷的修改会立马生效
  • 对数据卷的更新,不会影响镜像
  • 数据卷默认会一直存在,即使容器被删除

*注意:数据卷的使用,类似于 Linux 下对目录或文件进行 mount,镜像中的被指定为挂载点的目录中的文件会隐藏掉,能显示看的是挂载的数据卷。

二、数据卷的操作

1、创建一个数据卷

在用 docker run 命令的时候,使用 -v 标记来创建一个数据卷并挂载到容器里。在一次 run 中多次使用可以挂载多个数据卷。

docker run -d -P --name web -v /webapp training/webapp lexiaofei/ubuntu /bin/bash

2、删除一个数据卷

数据卷是被设计用来持久化数据的,它的生命周期独立于容器,Docker不会在容器被删除后自动删除数据卷,并且也不存在垃圾回收这样的机制来处理没有任何容器引用的数据卷。

如果需要在删除容器的同时移除数据卷。可以在删除容器的时候使用 docker rm -v 这个命令。

无主的数据卷可能会占据很多空间,要清理会很麻烦。Docker官方正在试图解决这个问题。

 docker rm -v

3、挂在一个主机目录作为一个数据卷

docker run -d -P --name web -v /src/webapp:/opt/webapp lexiaofei/ubuntu /bin/bash

加载 主机目录 /src/webapp 到容器的 /opt/webapp 目录。

Docker 挂载数据卷的默认权限是读写,用户也可以通过 :ro 指定为只读。
$ sudo docker run -d -P --name web -v /src/webapp:/opt/webapp:ro training/webapp python app.py

*注意:如果直接挂载一个文件,很多文件编辑工具,包括 vi 或者 sed --inplace,可能会造成文件 inode 的改变,从 Docker 1.1 .0起,这会导致报错误信息。所以最简单的办法就直接挂载文件的父目录。

4、查看容器挂在的数据卷信息

docker inspect web

docker 卷 覆盖 docker swarm 数据卷_python

在输出的内容中找到其中和数据卷相关的部分,可以看到所有数据卷都创建在主机的 /var/lib/docker/volumes/ 下。