数据卷可以将主机上的目录/文件映射到容器内,并具有以下一些特性:
$ docker volume create -d local test # 查看数据卷详细信息 $ docker volume inspect test [ { "CreatedAt": "2021-10-27T22:23:43+08:00", "Driver": "local", "Labels": {}, "Mountpoint": "/var/lib/docker/volumes/test/_data", "Name": "test", "Options": {}, "Scope": "local" } ]
可以看到,test创建在主机的 /var/lib/docker/volumes/test/_data
目录
# 创建容器时,docker create 和 docker run 都可以使用 -v 参数 # 使用具有名字的容器卷挂载到容器中 $ docker run -it --name ubuntu-1 -v test:/test ubuntu:18.04 # 使用指定目录挂载到容器中 $ docker run -it --name ubuntu-1 -v /test:/test ubuntu:18.04
挂载的的数据卷,在容器中的默认权限是读写,可以通过 ro
指定为只读:
$ docker docker run -it --name ubuntu-1 -v test:/test:ro ubuntu:18.04
加了 ro
之后,容器内就无法修改容器卷的文件了
如果需要在多个容器挂载共享多个数据卷,可以使用数据卷容器,数据卷容器的原理是这样的:
这样,相当于多个业务容器的数据卷配置,都来自于数据卷容器 data-container,仅需要配置一处
# 创建数据卷容器 $ docker create -v folder1:/folder1 -v folder2:/folder2 --name data-container ubuntu:18.04 # 创建业务容器1,使用数据卷容器 $ docker run -it --name container-1 --volumes-from data-container ubuntu:18.04 # 创建业务容器2,使用数据卷容器 $ docker run -it --name container-2 --volumes-from data-container ubuntu:18.04
使用数据卷容器,不需要数据卷容器在启动状态