总结
豆包 AI 助手文章总结
首页 > 运维 > Docker > 正文

Docker总结分享之数据卷技术

WBOY
发布: 2022-01-14 18:44:58
转载
1907人浏览过

本篇文章给大家带来了docker总结分享之数据卷技术的相关知识,希望对大家有帮助。

Docker总结分享之数据卷技术

Docker数据卷技术

19.png

什么是容器数据卷

docker的理念回顾

将应和环境打包成一个镜像!

数据?如果数据都在容器中,那么我们容器删除,数据就会丢失!需求:数据可以持久化

MySQL,容器删了,删库跑路--->需求:MySQL数据可以存储在本地!

容器之间可以有一个数据共享的技术!Docker容器中产生的数据,同步到本地!

这就是卷技术!目录的挂载,将我们容器内的目录,挂载到Linu×上面!

20.png

总结:容器的持久化和同步操作!容器间也是可以实现数据共享的!

使用数据卷

docker run -it -v 宿主机目录: 容器目录 -p 主机端口:容器端口 容器id
登录后复制

实战演练

inspect查看同步详细信息

21.png

在容器中创建一个文件,看是否同步到本地文件夹

22.png

在关闭容器的情况下,对本地文件进行修改,看修改的是不是会同步到容器中文件

23.png

Mysql实战

命令

docker run -d -p 3310:3306 -v /root/mysql/conf:/etc/mysql/conf.d -v /root/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
登录后复制

参数

-d 后台运行

-p 端口映射

-v 数据卷挂载:同步数据

-e  设置环境变量:这里时设置的时MySQL的登陆密码

--name  容器起名字

24.png

测试结果:连接成功

25.png

遇到的问题

首先使用的时mysql的最新版本:8.0----在使用navicat进行连接的时候,总是报莫名其妙的错误

解决方式:换成5.7版本,没有任何问题

在我们run镜像mysql的时候,没有加上-e MYSQL_ROOT_PASSWORD=123456进行密码的设置,容器一直会处于关闭状态,即使重新start也不会开启

加上-e MYSQL_ROOT_PASSWORD=123456这个参数完美开启

即使我们将容器删除,我们挂载到本地的数据卷依旧没有丢失,这就实现了容器数据的持久化功能

具名挂载和匿名挂载

匿名挂载

-v 容器内的路径!

docker run -d --name nginx01 -v /etc/nginx nginx
登录后复制

这里我们发现,这种就是匿名挂载,我们在-v的后面只是写上了容器内的路径,没有写容器外的路径

查看所有卷的情况

docker volume ls
登录后复制

26.png

具名挂载

-v 挂载卷的名称:容器内的路径

docker run -d --name nginx01 -v 具名挂在名称:/etc/nginx nginx
登录后复制

这里我们发现,这种就是匿名挂载,我们在-v的后面既写上了容器内的路径,没有容器外的路径,但是有一个名称

27.png

docker的内容目录:/var/lib/docker

所有的docker容器内的卷,没有指定目录的情况下都是在:/var/lib/docker/volume/xx/_data

我们可以通过具名挂载方便的找到我们的一个卷,并且在使用卷的时候最多的使用方式就是具名挂载

28.png

额外知识

如何区分时具名挂载还是匿名挂载,指定路径挂载

-v 容器内路径    #匿名挂载

-v 卷名:容器内路径    #具名挂载

-v /容器外路径:容器内路径    #指定路径挂载

扩展

-v 容器内路径:ro rw 改变读写权限

ro  readonly  只读

rw  readwrite 可读可写

一旦设置了这个容器权限,容器对我们挂载出来的内容就有限定了

docker run -d --name nginx01 -v 具名挂在名称:/etc/nginx:ro nginx
docker run -d --name nginx01 -v 具名挂在名称:/etc/nginx:rw nginx
登录后复制

Ro 只要看到ro就说明这个路径只能通过宿主机来进行操作,容器内是无法操作的!

初识Dockerfile

dockerfile

dockerfile就是用来构建docker镜像文件的!命令脚本!先体验一下

通过这个脚本可以生成镜像,镜像是一层一层的,脚本是一个个的命令,每个命令都是一层!

写一个dockerfile

# 创立一个dockerfile文件,名字可以随便的取,最好叫做dockerfile
# 文件中的内容 指令(大写) 参数
FROM centos
VOLUME ["volme01","volume02"]
CMD echo "--------end----------"
CMD /bin/bash
#这里每个指令就是镜像的一层
登录后复制

使用dockerfile生成镜像

docker build -f dockerfile文件位置 -t 镜像名称和版本 镜像生成的位置
登录后复制

29.png

进入镜像查看详情

30.png

查看卷的同步目录

docker ps -a

docker inspect 容器id

31.png

最后测试两个文件夹中是不是同步

同步成功

总结

使用dockerfile构建镜像的方式在我们未来的使用中非常的多,因为我们通常会构建自己的镜像

假设构建镜像时候没有挂载卷,要手动镜像挂载-v

数据卷容器

实际上即使保证的容器之间的数据共享的问题

32.png

数据卷容器实际上就是被拷贝数据的容器(A- volumes-from ->B,B是数据卷容器)

测试两个镜像之间同步

首先先开三个容器

创建docker01

33.png

创建docker02  --volumes-from docekr01

34.png

创建docker03  --volumes-from docekr02

35.png

查看docker01和docker03之间的数据共享

36.png

接着我们将docker02删除,查看docker01和docker03之间的数据共享

37.png

总结:

38.png

实现多个mysql之间的数据共享

  docker run -d -p 3310:3306 -v /root/mysql/conf:/etc/mysql/conf.d -v /root/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
  docker run -d -p 3310:3306 --volumes-from mysql01 -e MYSQL_ROOT_PASSWORD=123456 --name 
  mysql02 mysql:5.7
登录后复制

总结:

容器之间配置信息的传递。数据卷容器的声明周期一直持续到没有容器使用位置

理解:容器之间只要是共享就会数据copy,即使有的容器被删除,数据依然存在,直到所有共享 的容器都删除,数据才会被彻底删除

但是一旦你持久化到了本地,这个时候,本地的数据是不会删除的。

推荐学习:《docker视频教程

以上就是Docker总结分享之数据卷技术的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
相关标签:
来源:掘金网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
豆包 AI 助手文章总结
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号