介绍如何在Docker内部及容器之间管理数据,在容器中管理数据的两种方式:
- 数据卷
- 挂载主机目录
1 数据卷
数据卷是一个可供一个或多个容器使用的特殊目录,它绕过 UFS (UNIX File System) ,可以提供很多有用的特性:
- 数据卷可以在容器之间共享和重用
- 对数据卷的修改会立马生效
- 对数据卷的更新,不会影响镜像
- 数据卷默认会一直存在,即使容器被删除
1.1 步骤
- 创建一个数据卷
$ docker volume create myvol
查看所有的 数据卷
$ docker volume ls
DRIVER VOLUME NAME
local my-vol
在主机里使用以下命令可以查看指定 数据卷 的信息
$ docker volume inspect myvol
[
{
"Driver": "local",
"Labels": {},
"Mountpoint": "/var/lib/docker/volumes/my-vol/_data",
"Name": "myvol",
"Options": {},
"Scope": "local"
}
]
1.2 启动一个挂载数据卷的容器
在用docker run命令的时候,使用 --mount 标记来将 数据卷 挂载到容器里。在一次 docker run 中可以挂载多个 数据卷。
下面创建一个名为 web的容器,并加载一个 数据卷 到容器的 /user/share/nginx/html 目录。
docker run -d -p \
--name web \
--mount source=datawhale,target=/user/shares/nginx/html \
nginx:alpine
--mount参数说明:
source:数据卷
target:是容器内文件系统的挂载点
注意,可以不需要提前创建好数据卷,直接在运行容器的时候mount 这时如果不存在指定的数据卷,docker会自动创建,自动生成。
查看数据卷的具体信息:
--mount参数说明:
source:数据卷
target:是容器内文件系统的挂载点
注意:可以不需要提前创建好数据卷,直接在运行容器的时候mount 这是如是不存在指定的数据卷,docker会自动创建,自动生成。
1.3 查看数据卷的具体信息
在主机里使用以下命令可以查看web容器的信息
docker inspect web
删除数据卷:
docker volume rm datawhale #datawhale为卷名
数据卷是被设计用来持久化数据的,它的生命周期独立于容器,Docker 不会在容器被删除后自动删除 数据卷,并且也不存在垃圾回收这样的机制来处理没有任何容器引用的 数据卷。如果需要在删除容器的同时移除数据卷。可以在删除容器的时候使用 docker rm -v 这个命令。
无主的数据卷可能会占据很多空间,要清理请使用以下命令
$ docker volume prune