
9.容器数据卷
容器数据卷
1.什么是容器数据卷
如果数据都在容器中,那么我们容器删除,数据就会丢失!需求:数据持久化
MySQL,容器删了,数据就没了, 需求:MySQL数据可以存储在本地!
容器之间可以有一个数据共享的技术!Docker容器中产生的数据,同步到本地!
这就是卷技术!目录的挂载,将容器的目录,挂载到Linux上面
总结一句话:容器的持久化和同步操作!容器间也是可以数据共享的
2.使用数据卷
方式一:直接使用命令来挂载
docker run -it -v 主机目录:容器内目录
#测试
docker run -it -v /home/ceshi:/home centos /bin/bash
#启动起来后可以通过docker inspect 容器id
3.具名挂载和匿名挂载
# 匿名挂载
-v 容器内路径!
docker run -d -p --name nginx01 -v /etc/nginx
# 查看所有卷的情况
docker volume ls
local 4297b4870085dd67c5b39937956b2c7468b49780b1fbcc5cd25daeddc598470e
# 这里发现,这种就是匿名挂载, 我们在-v只写了容器内的路径,没有写容器外的路径
docker run -d -p --name nginx02 -v juming-nginx:/etc/nginx nginx
local juming-nginx
# 通过 -v 卷名:容器内路径
# 查看一下这个卷
docker volume inspect jumin-nginx
#所有的docker容器内的卷,没有指定目录的情况下都是在 `/val/lib/docker/volumes/xxx/_data`
root@VM-12-15-ubuntu:/# docker volume COMMAND
Usage: docker volume COMMAND
Manage volumes
Commands:
create Create a volume
inspect Display detailed information on one or more volumes
ls List volumes
prune Remove all unused local volumes
rm Remove one or more volumes
update Update a volume (cluster volumes only)
我们通过具名挂载可以方便的找到一个卷,大多数情况下在使用的
# 如何确定是具名挂载还是匿名挂载,还是指定容器挂载!
-v 容器内路径 # 匿名挂载
-v 卷名:容器内路径 #具名挂载
-v /宿主机路径:容器内路径 #指定路径挂载
扩展:
# 通过 -v 容器内路径:ro rw 改变读写权限
ro readonly 只读
rw readwrite 可读可写
#一旦设置了容器权限,容器对我们挂载出来的内容就有限定了
docker run -d -p --name nginx02 -v juming-nginx:/etc/nginx:ro nginx
docker run -d -p --name nginx02 -v juming-nginx:/etc/nginx:rw nginx
#ro 只要看到ro就说明这个路径只能通过宿主机来操作,容器内部无法操作
4.初识Dockerfile
Dockerfile就是用来构建docker镜像的构建文件!命令脚本!
通过这个脚本可以生成镜像,镜像是一层一层的,脚本是一个一个命令,每个命令都是一层
docker build -f dockerfile1 -t zjzaki/centos .
FROM centos
VOLUME ["volume01","volume02"]
CMD echo "-----end----"
CMD /bin/bash
启动容器后,多了两个挂载的目录
5.容器数据卷
多个MySQL同步数据!
# 启动3个容器,通过我们刚才自己写的镜像启动
docker run -it --name docker01 zjzaki/centos
#ctrl + p + q 退出当前这个
docker run -it --name docker02 --volumes-from docker01 zjzaki/centos
结论:
容器之间配置信息的传递,数据卷容器的生命周期一直持续到没有容器使用为止。
但是一旦持久化了本地,这个时候,本地的数据是不会被删除的
评论
匿名评论
隐私政策
你无需删除空行,直接评论以获取最佳展示效果