容器数据卷:
容器之间可以有一个数据共享的技术,Docker中产生的数据,同步到本地,这就是
卷技术!目录的挂载,将我们的容器内的目录,挂载到Linux上面。
容器的持久化和同步操作! 容器间也是可以数据共享的!
使用数据卷:
使用命令来挂载 -v(双向绑定)
docker run -it -v 主机目录:容器内目录
#测试 docker run -it /home/ceshi:/home centos /bin/bash
# 启动起来的时候可以使用 docker inspect 容器id (命令)来查看挂载信息
安装MYSQL:
思考:mysql的数据持久化问题!
#获取镜像
docker pull mysql:5.7
#运行容器,需要做数据挂载 #安装启动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=root --name mysql01 mysql:5.7
# -d后台运行
-p端口映射
-v卷挂载
-e环境配置
-name容器名字
将容器删除,挂载在主机上的数据卷不会丢失,这就实现了容器数据持久化功能!
具名和匿名挂载:
#匿名挂载
-v 容器内路径 (-P:随机映射端口)
docker run -d -P --name nginx02 -v /etc/nginx nginx
#查看所有的volume的情况
docker volume list
local e3eecbf0253b83908f4e7b5ba128ce94e0cf75f39675c141729bc21e65607404
这里发现,上面这种就是匿名挂载,我们在-v只写了容器内的路径,没有写容器外的路径!
#具名挂载
docker run -d -P --name nginx03 -v juming-nginx:/etc/nginx nginx
#查看volume的情况
local juming-nginx
#通过-v 卷名:容器内路径
#查看这个卷
所有docker容器内的卷,没有指定目录的情况都是在/var/lib/docker/volumes/XXX/_data
我们可以通过具名挂在可以方便找到卷,大多数情况下都是使用具名挂载!
#通过 -v 容器内路径:ro rw 改变读写权限
ro readonly #只读
rw readwrite #可读可写
#一旦设置了容器权限,容器对我们挂载出来的内容就有限定了!
测试:docker run -d -P --name nginx04 -v juming:/etc/nginx:ro nginx
docker run -d -P --name nginx04 -v juming:/etc/nginx:rw nginx
#ro 只要看到ro就说明这个路径只有通过宿主机来操作,容器内是无法操作的!
初识Dockerfile:
Dockerfile就是用来构建docker镜像的构建文件!命令脚本!
通过这个脚本可以生成镜像,镜像是一层一层的,脚本都是一个个命令,每个命令都是一层。
#创建一个dockerfile文件,文件名可以随意,建议取dockerfile
#文件中的内容,指令大写
FROM centos
#匿名挂载目录
VOLUME ["volume01","volume01"]
CMD echo "----end----"
CMD /bin/bash
#这里的每个命令。都是镜像的一层
数据卷容器
docker run -it --name docker02 --volumes-from docker01 zh/centos:1.0
#多个数据卷共享实行拷贝的概念,删除一个容器,另外一个容器的共享数据不会被删除!
多个mysql实现数据共享:
#mysql1
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=root --name mysql01 mysql:5.7
#mysql2
docker run -d -p 3311:3306
-e MYSQL_ROOT_PASSWORD=root --name mysql02 volumes-from mysql01 mysql:5.7
结论:容器间的配置信息的传递,数据卷容器的生命周期一直持续到没有容器使用为止!
但是一旦持久化到本地,这个时候,本地数据是不会删除的!