在上一篇中,咱们对Docker中的容器数据卷做了介绍。已经知道了容器数据卷是什么?能干什么用。那么本篇咱们就来实战容器数据卷,Docker容器数据卷案例主要做以下三个案例
1:宿主机(也就是Docker所安装的机器)与容器之间的映射-让Docker可以直接访问宿主机上面的指定目录;
2:读写规则映射添加说明-数据券默认是读写权限的,我们可以设置只读权限
3:卷的继承和共享-容器1做了映射后,容器2可以继承容器1,然后容器2也就有了映射关系
1:宿主机VS容器之间映射添加容器卷
docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录 镜像名
注意这个命令是在宿主机上执行
实例:
将宿主机/tmp/host_data目录映射到容器的/tmp/docker_data上
在d为:bdea29051ebb的容器i的/tmp/docker_data里面创建一个indocker.txt
接着,我们回到宿主机中,查看tmp/host_data目录下:
同理,在宿主机上创建了inhost.txt文件,在容器中也可以看到
命令公式:
docker inspect 容器id
再到 Mounts这个部分:
我们可以看到type是bind,sorce是宿主机的,destination是容器的
上文案例中的,indocker.txt和inhost.txt案例就是。
思考:当把容器关闭后,在宿主机的目录中,在创建了一个c.txt文件之后,在启动容器,那么容器的挂载目录中会有c.txt文件吗 ?
答案:c.txt文件依然会在容器中
当宿主机和容器挂载数据卷之后,默认的读写权限就是:“读写”
设置只读权限的命令公式
docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录:ro 镜像名称
和默认的区别就是加上了ro参数
ro:read only.
如果在容器内写操作会有以下提示:
案例:
容器1完成和宿主机的映射
容器2继承容器1的卷规则
容器2继承容器1的卷规则:
命令公式
docker run -it --privileged=true --volumes-from 父类 [name] 镜像名
在u2容器中,查看tmp目录