1、什么是容器数据卷?
docker的理念回顾
将应用和环境打包成一个镜像
引出问题
数据也打包的话,容器删了,数据不久没了吗?
解决
容器之间有一个数据共享技术,Docker容器中产生的数据,可以同步到本地,这就是卷技术,目录的挂载,将我们容器内的目录,挂载到Linux上面
也就是说:容器里的数据可以进行持久化和同步操作,并且容器间也是可以数据共享的
2、使用数据卷
方式一:直接使用命令来挂载 -v
# 命令
docker run -it -v 主机目录:容器目录 容器名 /bin/bash
# 测试
这是一个双向的过程,修改容器会同步到宿主机,同时,修改宿主机也会同步到docker容器
好处:我们以后修改只需要在本地即可,容器内会自动同步
3、实战:安装MySQL
# 安装MySQL
[root@iZbp12zsvvo3kfr5wvnm4lZ ~]# docker pull mysql:5.7
# 启动MySQL容器
# 官方测试:docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=123456
[root@iZbp12zsvvo3kfr5wvnm4lZ ~]# docker run -d -p 3306:3306 -v /home/mysql/conf:/etc/mysql/conf -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
134df666ed8f603765e4d2c9949a10d9f8986884849583126a67188158b5b02f
# 参数说明
-d 后台启动
-p 端口映射
-v 卷挂载
-e 环境配置
--name 容器名字
# 启动成功之后在本地使用sqlyog来测试
# 在本地测试创建一个数据库,查看映射路径是否ok
# 删除容器,数据仍不会丢失
4、具名和匿名挂载
# 匿名挂载
# -v 容器内路径
docker run -d -P --name nginx01 -v /ect/nginx nginx
# 查看所有卷的情况
[root@iZbp12zsvvo3kfr5wvnm4lZ data]# docker volume ls
DRIVER VOLUME NAME
local 5d644044c5becdfe8964093c830030f8e9ceaa2002de0466e64c414461e95eff
# 具名挂载
# -v 卷毛:容器内路径
[root@iZbp12zsvvo3kfr5wvnm4lZ home]# docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx
839d85b37df6f6211441399ff7c9880255431ba02d4e297f5bdc83e984a12288
[root@iZbp12zsvvo3kfr5wvnm4lZ home]# docker volume ls
DRIVER VOLUME NAME
local 5d644044c5becdfe8964093c830030f8e9ceaa2002de0466e64c414461e95eff
local juming-nginx
# 查看这个卷
[root@iZbp12zsvvo3kfr5wvnm4lZ home]# docker volume inspect juming-nginx
[
{
"CreatedAt": "2021-09-16T16:11:32+08:00",
"Driver": "local",
"Labels": null,
"Mountpoint": "/var/lib/docker/volumes/juming-nginx/_data",
"Name": "juming-nginx",
"Options": null,
"Scope": "local"
}
]
所有的docker容器,没有指定目录的情况下都在 /var/lib/docker/volumes/juming-nginx/_data
目录下
我们通过具名挂载可以方便的找到我们的一个卷,大多数情况下在使用 具名挂载
-v 容器内路径 # 匿名挂载
-v 卷名:容器内路径 # 具名挂载
-v /宿主机路径:容器内路径 # 指定路径挂载
拓展
我们经常能看到这样的命令:docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:ro nginx
参数ro是什么?
# -v 容器内路径:ro
ro readonly #只读
rw readwrite # 可读可写(默认)
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:ro nginx
# ro 表示只能通过宿主机操作,容器内部是无法操作的
5、初识DockerFile
方式二:构建镜像的时候直接挂载
DockerFile 用来构建docker镜像的构建文件,就是一个命令脚本
通过脚本可以生成镜像,镜像是一层一层的,脚本一个个的命令,每个命令都是一层
# 创建一个dockerfile文件
# 文件中的内容
FROM centos
VOLUME ["volume01","volume02"]
CMD echo "----end----"
CMD /bin/bash
运行容器进入内部
这个卷和外部一定有一个同步的目录
查看一下卷挂载的路径
测试一下刚才的文件是否同步出去了
这种方式对我们未来使用的十分多,因为我们通常会构建自己的镜像
加上构建镜像没有挂载卷,就要手动挂载
6、数据卷容器
多个mysql同步数据
# 启动三个容器
# 略
可以看到docker01创建的数据同步到了docker02里面
docker03也同理
# 测试 删除doker01后,doker02、docker03是否还存在文件
# 结果:存在
# 这是因为文件都挂载到了宿主机
多个mysql实现数据共享
docker run -d -p 3306:3306 -v /etc/mysql/conf.d -v /var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql
docker run -d -p 3306:3306 -v /etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456 --name mysql02 --volumes-from mysql01 mysql
结论
- 容器之间配置信息的传递,数据卷容器的生命周期一直持续到没有容器使用为止
- 但是一旦持久化到了本地,这个时候容器的数据是不会删除的