1 容器数据卷
docker的理念:将应用和环境打包成一个镜像!
思考:如果数据都在容器中,那么我们容器删除,数据就会丢失!---> 需求:数据可以持久化
MysqL容器,如果容器删除了,删库跑路!---> 需求:MysqL数据可以存储在本地!
容器之间可以有一个数据共享的技术!Docker容器中产生的数据,同步到本地!这就是卷技术!简单的说就是,目录的挂载,将我们容器内的目录,挂载到Linux上面!
总结一句话:容器的持久化和同步操作!容器间也是可以数据共享的!
2 使用数据卷
2.1 直接使用命令挂载 -v
格式:docker run -it -v 主机目录:容器内目录 -p 主机端口:容器内端口
命令:docker run -it -v /home/test:/home centos /bin/bash
打开主机 /home 目录,查看目录下的所有文件,然后使用命令挂载,挂载成功之后退出容器,再次查看 /home 目录下的所有文件,多了一个 test 文件夹
启动成功之后,在主机可以查看容器的元数据
命令:docker inspect 容器id
找到挂载信息
查看两个目录下的内容是否一致
再次测试
停止容器运行
重新启动容器,并进行文件查看
容器内的数据依旧是同步的
3 实战:安装MysqL
思考:MysqL 的数据持久化问题!
- 下载 MysqL 镜像
命令:docker pull MysqL:5.7
- 安装启动MysqL,需要配置密码的,这是要注意点!
官方启动:docker run --name some-MysqL -e MysqL_ROOT_PASSWORD=my-secret-pw -d MysqL:tag
命令:docker run -d -p 3310:3306 -v /home/MysqL/conf:/etc/MysqL/conf.d -v /home/MysqL/data:/var/lib/MysqL -e MysqL_ROOT_PASSWORD=123456 --name MysqL01 MysqL:5.7
参数说明:
- -d 后台运行
- -p 端口映射
- -v 卷挂载
- -e 环境配置
- -- name 容器名字
- 远程连接测试
命令:MysqL -h192.168.141.130 -P3310 -uroot -p123456
- 查看主机文件系统
创建数据库命令:create database test charset=utf8;
命令:docker rm -f 容器id
先别跑路啊~~~ 等一下~~~
- 再次确认,MysqL 容器已删
命令:docker ps -a
别跑啊~~~ 再等一下~~~
- 打开主机进行数据查看
不用跑了,哈哈~~
发现,我们挂载到本地的数据卷依旧没有丢失,这就实现了容器数据持久化功能。
4 具名和匿名挂载
- 匿名挂载 -v 容器内路径!
- 查看所有的volume的情况
命令:docker volume ls
这里发现,这种就是匿名挂载,我们在 -v只写了容器内的路径,没有写容器外的路径!
- 具名挂载 -v 卷名:容器内路径
命令:docker run -d -P --name Nginx02 -v juming-Nginx:/etc/Nginx Nginx
- 查看所有的volume的情况
命令:docker volume ls
- 查看一下这个卷
命令:docker volume inspect juming-Nginx
所有的 docker 容器内的卷,没有指定目录的情况下都是在 /var/lib/docker/volumes/xxxx/_data 下
如果指定了目录,docker volume ls 是查看不到的。
- 进去这个目录进行查看
可以通过具名挂载可以方便的找到任何一个卷,大多数情况下都在使用具名挂载
- 如何确定是具名挂载还是匿名挂载,还是指定路径挂载
-v 容器内路径 # 匿名挂载
-v 卷名:容器内路径 # 具名挂载
-v /宿主机路径:容器内路径 # 指定路径挂载 docker volume ls 是查看不到的
5 拓展
通过 -v 容器内路径:ro rw 改变读写权限
ro # readonly 只读
rw # readwrite 可读可写
docker run -d -P --name Nginx05 -v juming:/etc/Nginx:ro Nginx
docker run -d -P --name Nginx05 -v juming:/etc/Nginx:rw Nginx
ro:只要看到ro就说明这个路径只能通过宿主机来操作,容器内部是无法操作!
如果对您有帮助,赏口饭吃❤谢谢老板❤
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。