从零开始学 Docker-容器数据卷实战

一.什么是容器数据卷

通过前面的学习,我们知道 docker 是把应用和环境打包成镜像,那如果数据都在容器里,容器被删除数据就会丢失,我们需要让数据持久化。

卷又是什么呢?容器之间有数据共享,产生数据同步到本地,其实就是个目录挂载,把容器内的目录挂载到虚拟机上或者 linux 上面,这就是卷。把容器里想要同步的镜像里的一个路径映射到本地,也就是容器的持久化和同步操作,容器之间可以数据共享。

二.操作

2.1 挂载数据卷

命令: docker run -it -v /宿主机绝对路径目录:/容器内目录:[权限] 镜像名

权限:可以通过容器内路径:rw 这种方法修改权限为可读可写。ro 是只读,一旦设定了容器权限,容器对挂载出来的内容就有限定了。默认 rw, 如果为 ro,这个路径只能通过宿主机来操作,容器内部无法操作。可以通过在容器内路径后加上 ro、rw 来改变读写权限。

我们新建一个测试目录,然后使用命令: docker run -it -v /home/ceshi:/home centos /bin/bash 把centos映射到ceshi目录

使用之后会启动你在命令里写的镜像,然后我们进行测试。首先使用 docker inspect 容器id 来查看

可以在信息里发现这个,source 目的地,desti 是容器内地址,此时我们在 centos 或者主机内操作就会同步,我们来试试。

这里可以看到操作同步了,我们再试试主机内删除

然后进入 centos 内

我们可以看到操作确实同步了。

并且在停止容器之后,他依然会同步!只要容器在,没被删除就可以同步,并且可以挂载多个。

2.2 挂载方式

所有 docker 容器内的卷,没有指定目录的情况下都在/var/lib/docker/volumes/xxxxx/_data

指定路径挂载

-v /主机路径:容器内路径 上面就是

具名挂载

docker run -d -P --name nginx03 -v juming-nginx:/etc/nginx nginx

复制代码

这就是具名挂载,卷名:卷内路径。

我们可以通过 docker volume ls来查看挂载过的

可以看到我们的具名挂载是有名字的,我们也可以通过查看 juming-nginx 来看具体信息

可以看到路径也是和我们上面说的默认路径一样的!大部分情况就是使用具名挂载。(默认路径是在宿主机)

匿名挂载

docker run -d -P(随机映射端口)--name nginx02 -v /etc/nginx nginx

不写主机目录,会自动生成,上面 ls 查看的乱码都是没有指定名字的匿名卷,因为挂载的时候只写了容器内的路径,没有写容器外的路径,这就是匿名挂载。

那么如何判断是怎么挂载呢

只有容器内路径 匿名
卷名:容器内路径 具名
宿主机:容器内 指定路径

三.实战 mysql 持久化数据

3.1 下载 mysql

docker pull mysql:5.7

复制代码

3.2 运行容器(做数据挂载)

同步两个目录 链接 3310 和 3306 端口并且配置环境(密码)

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=123456 --name mysql01 mysql:5.7

3.3 测试

我们使用外部访问工具链接 mysql(我用的 navicat)

成功连接,然后我们在 navicat 里面新建一个表,看看宿主机会不会同步!

新建一个测试,然后去主机的 home/mysql/data 下面查看

我们可以发现,确实同步了!然后我们删除容器,查看主机里的数据是否还在

数据还在

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值