写点什么

【云原生】Docker 进阶 -- 数据卷使用与实战练习

作者:Bug终结者
  • 2022 年 8 月 15 日
    河北
  • 本文字数:2031 字

    阅读完需:约 7 分钟

【云原生】Docker 进阶 -- 数据卷使用与实战练习

📢📢📢📣📣📣<br>哈喽!大家好,我是【Bug 终结者,【CSDNJava 领域优质创作者】🏆,阿里云受邀专家博主🏆,51CTO 人气博主🏆 . <br/>一位上进心十足,拥有极强学习力的【Java 领域博主】😜😜😜 <br/>🏅【Bug 终结者】博客的领域是【面向后端技术】的学习,未来会持续更新更多的【后端技术】以及【学习心得】。 偶尔会分享些前端基础知识,会更新实战项目,面向企业级开发应用!🏅 如果有对【后端技术】、【前端领域】感兴趣的【小可爱】,欢迎关注【Bug 终结者】💞💞💞<br>❤️❤️❤️ 感谢各位大可爱小可爱! ❤️❤️❤️



一、什么是 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 镜像后,再次查看文件


docker rm -f mysql01
复制代码



数据已同步本地

⛵小结

以上就是【Bug 终结者】对 【云原生】Docker 进阶 -- 数据卷使用与实战练习 数据卷是我们持久化数据的一种方式,使用数据卷有效的保证了安全性与持久性,可谓是利器!


如果这篇【文章】有帮助到你,希望可以给【Bug 终结者】点个赞👍,创作不易,如果有对【后端技术】、【前端领域】感兴趣的小可爱,也欢迎关注❤️❤️❤️ 【Bug 终结者】❤️❤️❤️,我将会给你带来巨大的【收获与惊喜】💝💝💝!

发布于: 刚刚阅读数: 3
用户头像

Bug终结者

关注

励志成为一个优秀的开发者~ 2021.12.09 加入

星星之火,可以燎原

评论

发布
暂无评论
【云原生】Docker 进阶 -- 数据卷使用与实战练习_Docker_Bug终结者_InfoQ写作社区