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
文章图片
找到挂载信息
文章图片
查看两个目录下的内容是否一致
文章图片
文章图片
测试文件的同步:在容器的目录下创建文件 test.py,然后查看主机目录下内容是否发生变化
文章图片
文章图片
再次测试
停止容器运行
文章图片
在主机上添加 test.py 文件内容为:hello, Apollo!
文章图片
重新启动容器,并进行文件查看
文章图片
容器内的数据依旧是同步的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
文章图片
- 运行 mysql 容器,需要需要做数据挂载
命令: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
文章图片
- 查看主机文件系统
文章图片
- 在本地测试创建一个数据库,查看一下我们映射的路径是否ok!
创建数据库命令:create database test charset=utf8;
文章图片
- 查看主机文件系统,多了一个 test 文件
文章图片
- 删除 mysql 容器
命令:docker rm -f 容器id
文章图片
先别跑路啊~~~ 等一下~~~
- 再次确认,mysql 容器已删
命令:docker ps -a
文章图片
别跑啊~~~ 再等一下~~~
- 打开主机进行数据查看
文章图片
不用跑了,哈哈~~
发现,我们挂载到本地的数据卷依旧没有丢失,这就实现了容器数据持久化功能。4 具名和匿名挂载
- 匿名挂载 -v 容器内路径!
命令:docker run -d -P --name nginx01 -v /etc/nginx nginx
文章图片
- 查看所有的volume的情况
命令:docker volume ls【Docker学习|Docker 容器数据卷】
文章图片
这里发现,这种就是匿名挂载,我们在 -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 容器内路径# 匿名挂载5 拓展
-v 卷名:容器内路径# 具名挂载
-v /宿主机路径:容器内路径# 指定路径挂载 docker volume ls 是查看不到的
通过 -v 容器内路径:ro rw改变读写权限
ro# readonly只读
rw# readwrite可读可写
docker run -d -P --name nginx05 -v juming:/etc/nginx:ro nginxro:只要看到ro就说明这个路径只能通过宿主机来操作,容器内部是无法操作!
docker run -d -P --name nginx05 -v juming:/etc/nginx:rw nginx
如果对您有帮助,赏口饭吃?谢谢老板?
文章图片 |
文章图片 |
推荐阅读
- Docker|Docker第五篇【容器数据卷、匿名和具名挂载、DockerFile】
- git|qinglong青龙面板使用
- docker|docker 容器数据卷+具名挂载匿名挂载
- Docker|Docker第四篇【Docker镜像原理、commit镜像】
- Docker学习|Docker 镜像讲解
- Docker|Docker【2】 | 大白话带你快速安装Docker,不懂你捶我
- kubernetes|Kubernetes集群StorageClass持久化存储资源核心概念以及使用
- 青龙面板|青龙面板2.10.2搭建+XDD-PLUS搭建,保姆级搭建教程。【21年12月15日更新】
- Linux|Docker 常见环境问题