📢📢📢📣📣📣
哈喽!大家好,我是【Bug 终结者】 ,【CSDNJava领域优质创作者】🏆,阿里云受邀专家博主🏆,51CTO人气博主🏆 .
一位上进心十足,拥有极强学习力的【Java领域博主】😜😜😜
🏅【Bug 终结者】博客的领域是【面向后端技术】的学习,未来会持续更新更多的【后端技术】以及【学习心得】。 偶尔会分享些前端基础知识,会更新实战项目,面向企业级开发应用!
🏅 如果有对【后端技术】、【前端领域】感兴趣的【小可爱】,欢迎关注【Bug 终结者】💞💞💞❤️❤️❤️ 感谢各位大可爱小可爱! ❤️❤️❤️
文章目录
一、什么是Docker 数据卷?
Docker Volume 即数据卷,用于保持数据持久化,例如MySQL运行在Docker容器中时,一般将数据通过 Docker Volume 保存在主机上,这样即使删除MySQL容器,数据依然保存在主机上,有效保证了数据的安全性。
Docker Volume 就是一个目录或者文件,通俗的理解就是宿主机或者网络中存储系统中的一个目录或者文件挂载在容器中用于保存数据持久化
二、为什么要使用Docker Volume ?
Docker Volume 即数据卷,用于保持数据持久化,例如MySQL运行在Docker容器中时,一般将数据通过 Docker Volume 保存在主机上,这样即使删除MySQL容器,数据依然保存在主机上,有效保证了数据的安全性。
主要用于持久化数据
三、数据卷的使用
docker容器与宿主机挂载
docker run --it -v 主机目录:容器目录
docker run -it -v /home/ceshi:/home centos /bin/bash
启动成功进入 容器 home目录
新建测试文件,并退出
touch test.java
新开连接,去Linux主机 /home/ceshi查看文件是否同步
在Linux主机目录下写入内容
vim test.java
hello world !!!
:wq # 保存退出
查看是否与容器挂载,同步数据
docker inspect 6a737266eee4
启动容器,并进入查看修改的文件是否同步
# 启动容器docker start 容器id
# 进入容器docker attach 容器id
# 查看文件内容cat 文件名
共用一份存储空间
⚡提交自己的Commit镜像
下载启动tomcat
docker run -it -p 3355:8080 tomcat:9.0
新开连接去修改文件,默认的tomcat无法访问,因为缺少某些文件
我们可以看到webapps内的文件在webapps.dist中,所以我们将webapps.dist中的文件复制到webapps
我们通过公网ip访问出现以下界面
提交自己的镜像到dockerhub
docker commit -a="xiaowang" -m="add webapps app" c32d0e0c4a55 tomcat01:1.0
四、匿名挂载与具名挂载
# 匿名挂载nginxdocker run -d -P --name nginx02 -v /etc/nginx nginx
# 查看挂载的信息docker volume ls# 具名挂载nginxdocker run -d -P --name nginx03 -v juming-nginx:/etc/nginx nginx
# 查看 juming-nginx的挂载信息docker volume inspect juming-nginx
# ro:readonly,只读权限,容器只读,不可再容器内写入配置,只可在宿主机写入配置docker run -d -P --name nginx03 -v juming-nginx:/etc/nginx:ro nginx
# rw:readwrite,读写权限,可读可写,默认是rwdocker run -d -P --name nginx03 -v juming-nginx:/etc/nginx:rw nginx
具名挂载的信息
查看目录内的信息
五、容器数据卷
启动3个容器并同步
启动第一个容器在volume01写入文件
docker run --it --name docker01 xiaowang/centos
cd volumes01/
touch test.java
启动第二个容器并继承docker01
docker run -it --name docker02 --volumes-from docker01 xiaowang/centos
数据已同步
我们再启动第三个容器,也继承第一个容器
docker run -it --name docker03 --volumes-from docker01 xiaowang/centos
停止掉docker01容器,再次访问数据是否存在
查看docker2容器数据是否存在
我们可以看到依旧存在,是由于docker01指向了宿主机的一个地址,并将此设为共享空间,数据在此读取,所以停掉docker01,其它容器也可以拿到数据
备份拷贝机制,匿名挂载容器
容器之间配置信息的传递,数据卷容器的生命周期一直持续到没有人使用为止
六、实战:数据卷之MySQL同步数据
获取 mysql镜像
docker pull mysql
启动并同步本地mysql
# -d 后台运行# -p 映射端口 本地目录:容器目录 设置密码 重命名 以mysql5.7服务启动docker run -d -p 3355:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
**
注意:阿里云服务器需要开放安全组,Linux防火墙关闭
**
启动成功后使用SqlYog测试连接数据库
新建db_test数据库
本地服务器查看/home 目录下mysql文件
cd /home/mysql
删除mysql镜像后,再次查看文件
dockerrm -f mysql01
数据已同步本地
⛵小结
以上就是【Bug 终结者】对 【云原生】Docker 进阶 – 数据卷使用与实战练习 数据卷是我们持久化数据的一种方式,使用数据卷有效的保证了安全性与持久性,可谓是利器!
如果这篇【文章】有帮助到你,希望可以给【Bug 终结者】点个赞👍,创作不易,如果有对【后端技术】、【前端领域】感兴趣的小可爱,也欢迎关注❤️❤️❤️ 【Bug 终结者】❤️❤️❤️,我将会给你带来巨大的【收获与惊喜】💝💝💝!
版权归原作者 Bug 终结者 所有, 如有侵权,请联系我们删除。