文章目录
Docker入门到精通(三)
一、容器数据卷
1:什么是容器数据卷
如果数据都在容器中,那么我们容器删除,数据就会丢失!需求:数据可以持久化
★容器之间可以有一个数据共享的技术!!!Docker容器中产生的数据,同步到本地!这就是卷技术!目录的挂载,将我们容器内的目录,挂载到Linux上面!
★总结一句话:容器的持久化和同步操作!容器间也是可以数据共享的!
2:使用数据卷
直接使用命令来挂载,docker run -it -v 主机目录:容器内目录(类似于-p做映射)
// 解释
主机目录:/home/zhouziyu/dockerFile
容器内目录:/home
★docker run -it -v /home/zhouziyu/dockerFile: /home centos /bin/bash
★docker inspect 容器ID(查看元数据,是否挂载成功,并且开始测试文件的同步)
// 容器停止之后,仍可实现文件同步
好处:我们以后修改只需要在本地修改即可,容器内会自动同步!
二、Mysql进行数据同步
思考:Mysql的数据持久化的问题
1:搜索镜像(docker search mysql)
2:拉取镜像(docker pull mysql:5.7)
3:运行容器,需要做数据挂载(可以挂载多个)
需要注意用户名和密码
docker run -d -p 8080:3306 -v /home/zhouziyu/dockerMysql/conf:/etc/mysql/conf.d -v /home/zhouziyu/dockerMysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
-d 后台运行
-p 端口映射
-v 卷挂载
-e 环境配置
--name 容器名字
// 本地创建数据库xcgg
// Mysql容器删除后(docker rm -f 容器ID),我们挂载到本地的数据卷依旧没有丢失,这就实现了容器数据持久化功能!
三、具名挂载与匿名挂载
1:匿名挂载
-v 容器内路径
docker run -d -P(随机映射端口)--name nginx01 -v /etc/nginx nginx
★docker volume ls(查看所有卷的情况)
这种就是匿名挂载,我们在-v只写了容器内的路径,没有写容器外的路径!
2:具名挂载(推荐)
-v 具名(不要加“/”):容器内路径
docker run -d -P(随机映射端口)--name nginx02 -v juming-nginx:/etc/nginx nginx
★docker volume ls(查看所有卷的情况)
通过-v 卷名:容器内路径
所有的Docker容器内的卷,没有指定目录的情况下都是在:
/var/lib/docker/volumes/xxxx/_data下面!!!
如何确定是具名挂载还是匿名挂载,还是指定路径挂载?
★-v 容器内路径(匿名挂载)
★-v 卷名:容器内路径(具名挂载)
★-v /宿主机路径:容器内路径(指定路径挂载)
拓展(容器内路径后面出现ro或者rw):
通过 -v 容器内路径:ro/rw 改变读写权限
ro readonly(只读,说明这个路径只能通过宿主机来操作,容器内部是无法操作的!)
rw readwrite(可读可写,默认的)
// 一旦设置了容器权限,容器对我们挂载出来的内容就有限定了!
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:ro nginx
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:rw nginx
四、数据卷之DockerFile(体验初识)
DockerFile就是用来构建Docker镜像的构建文件!(之前通过commit生成过镜像)命令脚本,先体验一下!通过这个脚本可以生成镜像,镜像是一层一层的,脚本一个个的命令,每个命令都是一层!
// 开始编写脚本(指令需要大写)
FROM centos
VOLUME [“volume01”,”volume02”](挂载卷,匿名挂载)
CMD echo “-----end-----”
CMD /bin/bash
★docker build -f dockerfile -t xcgg/centos:1.0 .(不要忘记最后的“.”)
// 解释
-f(编写脚本dockerfile的地址)
-t(通过dockerfile生成镜像名:tag)
// 启动自己写的容器
★docker run -it 镜像ID /bin/bash
这个卷和外部一定有一个同步的目录!(docker inspect 容器ID 查看)
这种方式我们未来使用的十分多,因为我们通常会构建自己的镜像,假设构建镜像时没有挂载卷,要手动镜像挂载 -v 卷名:容器内路径!
五、数据卷容器
多个Mysql实现同步数据(--volumes-from,共享数据)
// 启动3个容器,通过我们刚才自己写的镜像
docker run -it --name docker01 xcgg/centos:1.0
docker run -it --name docker02 --volumes-from docker01 xcgg/centos:1.0
★docker inspect 容器ID(查看docker01元数据)
★docker inspect 容器ID(查看docker02元数据)
docker run -it --name docker03 --volumes-from docker01 xcgg/centos:1.0
// docker01容器删除后,docker02与docker03的相关数据还会存在(拷贝的概念)
// 多个Mysql实现数据共享(可以实现两个容器数据同步)
docker run -d -p 8080:3306 -v /etc/mysql/conf.d -v /var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
docker run -d -p 8081:3306 -e MYSQL_ROOT_PASSWORD=123456 --volumes-from mysql01 --name mysql02 mysql:5.7
结论:
容器之间配置信息的传递,数据卷容器的生命周期一直持续到没有容器使用为止。但是一旦你持久化到了本地,这个时候,本地的数据是不会删除的!
总结
每天一个提升小技巧!!!