容器数据卷技术
什么是容器数据卷
docker理念:
将一个应用所需的环境和代码打包成一个镜像。
在此过程中出现的场景:
**数据是否也在容器中存储?**如果数据在容器中存储,当容器删除,数据也就没有了!!
需求:数据的可持久化
例如MySQL的部署,如果镜像删了,mysql内的数据也就丢失?需求:数据可以存储到本地
容器之间有一个数据共享的技术!Docker容器中产生的数据同步到本地!这就是卷技术,目录的挂载,将容器内部的目录挂载到Linux的目录中。
**总结:**卷技术可以完成容器的持久化和同步操作!容器之间也是可以数据共享的!
使用数据卷
方式一:直接使用命令来挂载 -v
docker run -it -v 主机目录:容器内目录 容器id
#测试
[root@iZbp15mbkzmyf9l6lx443nZ //]# docker run -it -v /home/juan-ceshi:/home centos /bin/bash
#启动起来之我们可以通过:docker inspect 容器id 查看具体挂载的详细挂载信息,如下图
测试文件的同步过程:
在挂载后的容器内目录中创建test.java,查看与之对应的linux下挂载的目录,test.java文件已经同步过来。
再来测试:
- 停止这个cents容器
- 在linux的挂载目录上修改test.java文件
- 启动容器,查看容器中挂载的目录下的test.java
- 观察发现容器内的文件也是同步的
使用容器卷的好处:
对于一些配置文件等(例如nginx的配置文件),以后我们修改只需要在本地对应的挂载目录中进行修改,容器会自动同步到对应的容器内部的挂载目录!
实战:安装mysql
思考:
MySQL的数据持久化问题
# 获取镜像
[root@iZbp15mbkzmyf9l6lx443nZ //]# docker pull mysql:5.7
# 运行容器,需要做数据挂载,安装启动mysql的时候需要配置密码的
# 官方测试docker启动mysql的时候需要配置密码
-e MYSQL_ROOT_PASSWORD=
# 启动mysql
-d 后台运行
-p 端口映射
-v 卷挂载
-e 环境配置
--name 容器名字
[root@iZbp15mbkzmyf9l6lx443nZ //]# docker run -d -p 4406:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=mzc277171 --name mysql01 mysql:5.7
e8bd73b8ac07754be746810fb1528fc5ccd281cf057afa5b0ed68728e396116f
# 启动成功后本地用sql的客户端进行连接,测试是否连接成功
具名挂载和匿名挂载
#匿名挂载
-v 容器内路径
docker run -d -P --name nginx1 -v /etc/nginx nginx
#查看所有 volume情况
[root@iZbp15mbkzmyf9l6lx443nZ //]# docker volume ls
DRIVER VOLUME NAME
local 17327107c6f42108a7bac35e7236ea42d0ae74ecaec02b17a532192707e8d05c
local ccfa89beffecacebf7c33f209cc542af65ae291973b6db342cfde1589a2197b8
#具名挂载
docker run -d -P --name nginx1 -v juming-nginx:/etc/nginx nginx
#通过-v 卷名:容器内路径
所有的docker容器内的卷,没有指定目录的情况下是在“/var/lib/docker/volumes/xxxx”
我们通过具名挂载,可以方便的找到我们的一个卷,大多数情况下我们使用的是具名挂载。
#如何确定是具名挂载还是匿名挂载
-v 容器内路径 #匿名挂载
vi 卷名:容器内路径 #具名挂载
-v /宿主机路径:容器内路 #指定路径挂载
拓展:
#通过 -v 容器内路径:ro rw 改变读写的权限
ro readonly #只读
rw readwrite #可读可写
#一旦设置了这个容器权限,容器对于我们挂载出来的内容就有限定了!
docker run -d -P --name nginx1 -v juming-nginx:/etc/nginx:ro nginx
docker run -d -P --name nginx1 -v juming-nginx:/etc/nginx:rw nginx
#ro 只要看到ro就说明这个路径只能通过宿主机进行操作,容器内部是无法操作的。