容器数据卷
- 一.什么是容器数据卷
- 二.使用数据卷
- 方式一:直接使用命令来挂载 -v
- 三.具名和匿名挂载
一.什么是容器数据卷
docker理念
将应用和环境打包成一个镜像!
数据?如果数据都在容器中,那么我们的容器删除,数据就会丢失! 需求:数据可以持久化
MYSQL,容器删除了,删库跑路! 需求:MYSQL数据可以存储在本地!
容器之间可以有一个数据共享技术!Docker容器产生的数据,同步到本地!
则就是容器技术!目录的挂载,将我们容器中的目录,挂载到Linux上
总结:容器的持久化和同步操作!荣期间也是可以数据共享的!
二.使用数据卷
方式一:直接使用命令来挂载 -v
[root@docker test]# docker run -it -v 主机目录:容器目录
# 测试
[root@docker home]# docker run -it -v /home/test:/home centos
# 启动起来时我们通过docker inspect 容器id
测试文件的同步
停止容器
宿主机上修改文件
启动容器
容器内数据依旧是同步的
实战:安装mysql
思考:mysql数据持久化的问题
# 获取镜像
[root@docker home]# docker pull mysql:5.7
# 运行容器,需要做数据挂在! #安装启动mysql,需要配置密码,注意要点
# 官方测试:docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-sercert-pw -d mysql:tag
# 启动我们的
-d 后台运行
-p 端口映射
-v 卷挂载
-e 环境配置
--name 容器名字
[root@docker home]# docker run -d -p 3306:3306 -v /home/mysql/conf:/etc/my.cnf -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
# 启动成功之后,我们本地使用dbeaver测试
# 通过本机的3306 --- 容器的3306映射
假设我们将容器删除
发现,我们挂载到本地的数据卷依旧没有丢失,这就实现了容器数据持久化功能!
三.具名和匿名挂载
# 匿名挂载
-v 容器内路径!
docker run -d -P --name nginx01 -v /etc/nginx nginx
# 查看所有的volume情况
[root@docker ~]# docker volume ls
DRIVER VOLUME NAME
local 2bfd52dcc305b4fd6a14ab6995ad0b4d64d7324f81e77bcf2a14b3ff86b5c242
# 这里发现,这种就是匿名挂载,我们在-v只写了容器的路径,没有写容器外的路径
#具名挂载
[root@docker ~]# docker run -d -P --name nginx02 -v test_nginx:/etc/nginx nginx
777acae83df92a58b91264d691786ad312e27e6a81f6503973319343f6cfd56d
[root@docker ~]# docker volume ls
DRIVER VOLUME NAME
local test_nginx
# 通过 -v 卷名:容器内路径
查看一下这个卷
所有的docker容器的卷,没有指定目录的情况下都是在 /var/lib/docker/volumes/xxxx/_data
我们通过具名挂可以方便的找到我们的一个卷,大多数情况使用的是具名挂载
如何确定是具名挂载还是匿名挂载,还是指定路径挂载
-v 容器内路径 # 匿名挂载
-v 卷名:容器内路径 # 匿名挂载
-v /宿主机路径:容器内路径 # 指定路径挂在
拓展
# 通过 -v容器内路径:ro rw 改变读写权限
ro readonly # 只读
rw readwrite # 可读可写
# 一旦这个设置了容器权限,容器对我们挂载出来的内容就有限定了
docker run -d -P --name nginx01 -v test_nginx:/etc/nginx:ro nginx
docker run -d -P --name nginx01 -v test_nginx:/etc/nginx:rw nginx
# ro 只要看到了ro就说明这个路径只能通过宿主机来操作,容器内部是无法操作的