7. Docker 容器数据卷的使用(超详细的讲解说明)

打印 上一主题 下一主题

主题 1016|帖子 1016|积分 3048

7. Docker 容器数据卷的使用(超详细的讲解说明)

@
目录

坑:容器卷(一定一定)记得加入 --privileged=true
Docker挂载主机目录访问如果出现 cannot open directory .: Permission denied
解决办法:在挂载目录后多加一个 --privileged=true 参数即可。
如果是CentOS7安全模块会比之前系统版本加强,不安全的会先克制,所以目录挂载的情况被默认为不安全的行为,在SELinux内里挂载目录被克制掉了额,如果要开启,我们一样平常使用--privileged=true命令,扩大容器的权限解决挂载目录没有权限的问题,也纵然用该参数,container内的root拥有真正的root权限,否则,container内的root只是外部的一个普通用户权限。

1. Docker容器数据卷概述

Docker 容器数据卷是什么:
一句话:有点雷同我们 Redis 内里的 rdb 和 aof 文件。
将 docker 容器内的数据生存进宿主机的磁盘中,如许每次启动的容器实例当中的数据,都是从宿主主机(或者是另外的一个服务器存储数据的)当中读取的数据都还在,并不会因为容器实例删除了,数据而消失了。
运行一个带有容器卷存储功能的容器实例 ——>  docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录      镜像名
  1. docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录      镜像名
复制代码
Docker 容器数据卷能做什么:?
将运用与运行环境打包镜像, run 后形成容器实例运行,但是我们对数据的要求希望是:持久化的
Docker 容器产生的数据,如果不备份,那么当容器实例删除后,容器内的数据天然也就没有了。
为了能生存数据在 Docker 中我们使用卷。
特点:

  • 数据卷可在容器之间共享或重用数据。
  • 卷中的更改可以直接实时生效。
  • 数据卷中的更改不会包含在镜像的更新中。
  • 数据卷的生命周期不停持续到没有容器使用它为止。
2. Docker 容器数据卷的使用演示:

2.1 宿主 和 容器之间映射添加容器卷

命令  docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录      镜像名
  1. docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录      镜像名
复制代码
  1. 公式:docker run -it -v /宿主机目录:/容器内目录 ubuntu /bin/bash
复制代码
  1. docker run -it --name myu3 --privileged=true -v /home/linux/demo02/tmp/myHostData:/tmp/myDockerData ubuntu /bin/bash
复制代码

  • 特别说明:--name 表示配置该容器实例的名称。


检察数据卷是否挂载乐成:
  1. docker inspect 容器ID
复制代码
  1. [root@localhost ~]# docker inspect 68a414008829
复制代码

容器和宿主机之间数据共享:

  • docker修改,主机同步获得


  • 主机修改,docker同步获得


  • docker容器 stop,主机修改,docker容器重启看数据是否同步。



2.2 容器数据卷 读写规则映射添加说明


默认配置的(没有特别说明的容器数据卷),默认就是可读可写(rw) 的。
  1. docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录:rw      镜像名
复制代码
只读配置:生成配置容器数据卷的时候 ,ro
只读:容器实例内部被限制,只能读取不能写。

这种场景,一样平常不常用,都是因为你要存数据,都是从容器实例当中的数据,写入到主机(或者其他的存储器服务器)当中进行一个备份。防止容器实例关闭了,数据丢失掉了。
2.3 容器数据卷的继续和共享


  • 容器1完成和宿主机的映射:
  1. docker run -it  --privileged=true -v /mydocker/u:/tmp --name u1 ubuntu
复制代码


  • 创建容器实例 u2 并继续容器 u1的卷规则
公式如下:
  1. docker run -it  --privileged=true --volumes-from 父类  --name u2 ubuntu
复制代码
  1. docker run -it  --privileged=true --volumes-from u1  --name u2 ubuntu
复制代码

u2 就继续 u1 容器实例的全部内容,比如:容器数据卷的路径,以及当中的内容数据。



3. 最后:

“在这个最后的篇章中,我要表达我对每一位读者的感激之情。你们的关注和回复是我创作的动力源泉,我从你们身上吸取了无尽的灵感与勇气。我会将你们的鼓励留在心底,继续在其他的领域奋斗。感谢你们,我们总会在某个时候再次相遇。”


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

王海鱼

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表