文章目录
前文曾提到,容器删除时,数据也会被删除,那么 docker
是如何固化数据的呢?
本章节介绍 docker
数据管理的两种方式。
1. 数据卷
数据卷
是一个特殊的目录,可以供一个或多个容器使用,它绕过了 UFS (UNIX File System)
系统,具有如下几个特性:
- 数据卷可以共享和重用
- 对数据卷的修改会立马生效
- 对数据卷的更新,不影响镜像
- 数据卷默认一直存在,即使容器被删除
数据卷的使用,类似于 Linux 下对目录或文件进行 mount。
在镜像中,被指定为挂载点的目录下的文件会复制到数据卷中(仅数据卷为空时会复制)。
1.1 创建数据卷
- 创建:
docker volume create mba1398
- 查看数据卷列表:
docker volume ls
- 查看数据卷详情:
docker volume inspect mba1398
1.2 启动一个挂载数据卷的容器
使用 docker run
命令时,--mount
参数用来标记来将 数据卷
挂载到容器里。在一次 docker run
中可以挂载多个 数据卷。
下面创建一个名为 web
的容器,并加载一个 数据卷 到容器的 /usr/share/nginx/html
目录。
$ docker run -d -P \
--name web \
# -v mba1398:/usr/share/nginx/html \
--mount source=mba1398,target=/usr/share/nginx/html \
nginx:v3
ps: 数据卷无需使用前创建,
docker run
命令中使用-v
参数即可自动创建。
1.3 查看数据卷配置信息
查看数据卷信息命令:docker inspect web
数据卷
信息在 “Mounts” Key 下面:
1.4 删除数据卷
数据卷
是用来固化数据的,它的生命周期独立于容器,不因容器删除而丢失,也不存在垃圾回收的机制处理没有任务容器引用的 数据卷
,因此,数据卷
需要手动删除,删除命令为:docker volume rm mba1398
(示例)。如果希望在删除容器的同时移除数据卷。可以在删除容器的时候使用 docker rm -v
命令。
需要注意的是,无主的 数据卷
会占用较多的空间,手动逐个删除会很麻烦,这里提供一个批量删除 数据卷
的命令:docker volume prune
。
2. 挂载宿主机目录
除了上面介绍的方式,还可以通过挂载本地目录的方式来固化数据。
2.1 挂载宿主机目录至容器(作为数据卷)
首先,我们在宿主机创建一个目录 docker_datawave
,然后通过如下命令进行挂载:
docker run -d -P \
--name web \
--mount type=bind,source=/mnt/e/docker_datawave,target=/usr/share/nginx/html,readonly \
nginx:v3
在上面的命令中:
--name
:containerName
--mount
:挂载标志,用于挂载本地文件夹/文件到容器type
:挂载文件类型source
: 本地绝对路径target
:容器目录(挂载目标路径)readonly
:挂载本地目录的默认权限是读写
,可以通过readonly
参数将挂载目录指定为只读
。此时在容器中的/usr/share/nginx/html
目录新建文件,会报错:
2.2 查看挂载目录配置信息
查看 挂载目录
配置信息的命令和查看 数据卷
配置信息时的命令一致。
首先通过 docker inspect web
命令查看容器信息,然后,挂载宿主机目录
的配置信息就在 "Mounts" Key
下面:
2.3 挂载本地文件至容器(作为数据卷)
除了可以挂载本地目录至容器,我们也可以挂载本地文件至容器。使用命令如下:
docker run --rm -it \
--mount type=bind,source=/mnt/e/docker_datawave/datawhale.txt,target=/var/log/abc.txt \
ubuntu:18.04 \
bash
结束。