数据卷容器

什么是数据卷容器?

容器和容器之间实现数据共享

  • 一个容器先于宿主机创建挂载方式,宿主机就会有改卷的目录
  • 第二个容器使用命令--volumes-from 第一个容器,共享使用了第一个容器与宿主机创建的卷。第一个容器就被称之为数据卷容器
  • 第三个容器使用命令--volumes-from 第一个容器,共享使用了第一个容器与宿主机创建的卷
  • ……

总结:数据卷容器,实际上是第一个容器跟宿主机创建了卷,其他容器通过第一个容器使用这个卷。

  • 类似于具名挂载,具名挂载是-v的时候选择卷名,减少重复输入相同路径,输入卷名就可以。
  • 而这个是先让第一个跟宿主机先创建卷,通过--volumes-from这个容器名,来使用这个卷
  • 区别就是,具名挂载:-v 卷名;数据卷容器挂载:--volumes-from 容器名
  • 数据卷容器的生命周期一直持续到没有容器使用为止,虽然容器不在了,卷以及本地目录还在,但这种方式叫做数据卷容器
  • 换汤不换药,仅仅是我个人理解,不喜忽喷

#docker01容器,后面docker02、docker03都会--volumes-from docker01;因此docker01就是一个数据卷容器

[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
centos latest 300e315adb2f 8 months ago 209MB

# 启动镜像,创建容器,使用匿名挂载方式,容器挂载路径为容器根目录下的volume文件夹
[root@localhost ~]# docker run -it --name docker01 -v /volume 300e315adb2f /bin/bash
[root@7b7b500a1959 /]# ls
bin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var volume
[root@7b7b500a1959 /]# cd volume/
[root@7b7b500a1959 volume]# touch ceshi.java
[root@7b7b500a1959 volume]# ls
ceshi.java
[root@7b7b500a1959 volume]#

#docker02容器,--volumes-from docker01;

[root@localhost ~]# docker run -it --name docker02 --volumes-from docker01 300e315adb2f /bin/bash
[root@259ffb447fc3 /]# ls
bin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var volume
[root@259ffb447fc3 /]# ls /volume/
ceshi.java

#docker03容器,--volumes-from docker01;

[root@localhost ~]# docker run -it --name docker03 --volumes-from docker01 300e315adb2f /bin/bash
[root@ecb8e7443ea2 /]# ls
bin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var volume
[root@ecb8e7443ea2 /]# ls volume/
ceshi.java

# 思考!,删除数据卷容器docker1后,docker02和docker03是否还看可以访问这个目录?

# 当然可以,我就不试了,你把docker1删了,但是卷还在,所以对其他两个没有任何影响;
# 如果我们使用命令volume rm 把卷删了,会发生什么情况?猜一下,docker01自身这个目录应该是在的,但是另外两个容器访问不了,因为毕竟是docker01将自己的volume目录贡献出去的。(文首总结内容是根据猜想来的)
[root@localhost ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
ecb8e7443ea2 300e315adb2f "/bin/bash" 37 minutes ago Exited (130) 9 minutes ago docker03
259ffb447fc3 300e315adb2f "/bin/bash" 37 minutes ago Exited (0) 9 minutes ago docker02
7b7b500a1959 300e315adb2f "/bin/bash" 40 minutes ago Exited (0) 11 minutes ago docker01

# 查看docker01容器详细信息,获取卷的名称
[root@localhost ~]# docker inspect 7b7b500a1959

#找到了开始删除,发现删不掉,加了强删除-f,依旧不行,提示有容器在使用
#把docker01、docker02、docker三个容器都stop掉,哎,还是删不掉
[root@localhost ~]# docker volume rm -f 88cedeabc85d030bfcab43f03f5aabbea99a7f4c4f211cd691ee492cb160f9c8
Error response from daemon: remove 88cedeabc85d030bfcab43f03f5aabbea99a7f4c4f211cd691ee492cb160f9c8: volume is in use - [ecb8e7443ea251a0383ededfa6306fdf24b05b6194985da5a3fd880af1f5f53a, 7b7b500a19592b72943b28badf6a95d04937d3e363936e4c7775f9c44aae61d1, 259ffb447fc3e7abe0868f7da606bd988fbf7582ee96ec21dbf075c6cfdb6165]

#分别查看另外两个容器的挂载信息,发现另外两个容器的卷都是88cedeabc85d030bfcab43f03f5aabbea99a7f4c4f211cd691ee492cb160f9c8
[root@localhost ~]# docker inspect ecb8e7443ea251a0383ededfa6306fdf24b05b6194985da5a3fd880af1f5f53a
[root@localhost ~]# docker inspect 259ffb447fc3e7abe0868f7da606bd988fbf7582ee96ec21dbf075c6cfdb6165

# 分析,相当于docker02、docker03虽然是通过--volume from docker01 实现数据同步的;但是各自都同步了这个目录;docker01数据容器卷就可以理解为具名挂载的卷名。通过实践证明,文首总结的内容。
# 删哪个容器这个目录以及文件都在,即使三个容器全删完了都还在,因为宿主机还有。妙啊!!!

需求:多个mysql同步数据

[root@localhost ~]# docker run -d -p 3310:3306 --name mysql01 -v /home/mysql/conf:/etc/mysql/conf.d  -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7

[root@localhost ~]# docker run -d -p 3310:3306 --name mysql02 --volumesfrom-mysql01 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7

[root@localhost ~]# docker run -d -p 3310:3306 --name mysql03 --volumesfrom-mysql01 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7

# 这个时候三个数据库容器的数据就实现同步了

Docker系列(20)- 数据卷容器的更多相关文章

  1. 【Docker】利用数据卷容器来备份、恢复、迁移数据卷

    利用数据卷容器来备份.恢复.迁移数据卷 可以利用数据卷对其中的数据进行进行备份.恢复和迁移. 备份 首先使用 --volumes-from 标记来创建一个加载 dbdata 容器卷的容器,并从主机挂载 ...

  2. Docker系列八: 数据卷

    什么是数据卷 生成环境中使用docker的过程中,往往需要对数据进行持久化,或者需要多个容器之间进行数据共享,这个就涉及到了容器数据管理 容器中管理数据主要有两种方式: 数据卷:容器内数据之间映射到本 ...

  3. 聊聊Docker数据卷和数据卷容器

    当程序在容器运行的时候,特别是需要与其他容器中的程序或容器外部程序进行沟通交流,这时需要进行数据交换,作为常用的两种沟通数据的方式,网络通信与文件读写是需要提供给程序的支持, [数据卷] 文件是数据持 ...

  4. 『现学现忘』Docker基础 — 33、Docker数据卷容器的说明与共享数据原理

    目录 1.数据卷容器的说明 2.数据卷容器共享数据原理 3.总结 4.练习:MySQL实现数据共享 1.数据卷容器的说明 (1)什么是数据卷容器 一个容器中已经创建好的数据卷,其它容器通过这个容器实现 ...

  5. docker对数据卷容器进行备份

    转载请注明出处 官网的数据以及各大博客都没有对这个的具体说明,本人也是理解了好久. 我们使用docker的过程中,使用共享的数据卷是经常的,那么.我们要怎么进行备份呢?   首先,我们得了解下面4个命 ...

  6. Docker学习笔记 - Docker的数据卷容器

    一.什么是数据卷容器 如果你有一些持续更新的数据需要在容器之间共享,最好创建数据卷容器. 数据卷容器:用于容器间的数据共享,主动挂载宿主机目录,用于其他容器挂载和共享. 二.数据卷容器的操作 1.创建 ...

  7. Docker 数据卷容器

    如果你有一些持续更新的数据需要在容器之间共享,最好创建数据卷容器. 数据卷容器,其实就是一个正常的容器,专门用来提供数据卷供其它容器挂载的. 首先,创建一个命名的数据卷容器 dbdata: $ sud ...

  8. docker 数据卷和docker数据卷容器以及数据卷的备份和还原

    一:数据卷 1.什么是数据卷 数据卷是通过特殊设计的目录,可以绕过联合文件系统,为一个或者多个容器提供服务,数据卷是在docker宿主机当中,数据卷可以是文件也可以是文件夹. 2.特点 1.数据卷在容 ...

  9. Docker数据卷容器备份、恢复

    1.备份数据卷容器 使用数据卷来备份数据,通过指定本地的一个文件路径,对应到容器中的路径,运行tar命令将重要的文件打包备份. $ cd /home/xm6f/dev $ docker run --v ...

随机推荐

  1. CVE-2020-0796提权操作

    简介 最新的windows10中使用了SMBv3协议,SMBv3协议在压缩消息时,未对头部数据做任何检查,导致恶意攻击者可以直接使用,从而导致内存破坏漏洞. 该漏洞可远程进行攻击目标系统,但目前只做到 ...

  2. ECDSA—模加减模块

    如果a,b GF(P),则加法运算a+b=r (mod p),其中r满足0<r<p-1,即a+b除以p的余数,该操作成为模p加法.对于模减运算可以视为另类的模加运算,即a+(-b)=k ( ...

  3. Java中Lambda表达式基础及使用详解

    概述 Lambda 是JDK 8 的重要新特性.它允许把函数作为一个方法的参数(函数作为参数传递进方法中),使用 Lambda 表达式可以使代码变的更加简洁紧凑,使Java代码更加优雅. 标准格式 三 ...

  4. 【springboot】整合 MyBatis

    转自:https://blog.csdn.net/cp026la/article/details/86493503 1. 简介: 目前,国内大部分公司都使用 MyBatis作为持久层框架.本章整合My ...

  5. C++继承体系中的内存分段

    ---------------综述与目录-------------- 讨论这个问题之前我们先明确类的结构,一个类的大概组成,下面的很多分类名词都是我个人杜撰,为的就是让读者看懂能够区分,下面分别分类: ...

  6. 【java虚拟机】内存分配与回收策略

    作者:平凡希 原文地址:https://www.cnblogs.com/xiaoxi/p/6557473.html 前言 对象的内存分配,往大的方向上讲,就是在堆上分配,少数情况下也可能会直接分配在老 ...

  7. 【springcloud】Zuul高级配置(zuul--2)

    转自:https://blog.csdn.net/pengjunlee/article/details/87162192 自定义路由规则 在<API Gateway 的路由和过滤(Zuul)&g ...

  8. 深入浅出Mybatis系列(九)---缓存

    MyBatis系统中默认定义了两级缓存:一级缓存和二级缓存. 1.默认情况下,只有一级缓存(SqlSession级别的缓存,也称为本地缓存)开启. 2.二级缓存需要手动开启和配置,他是基于namesp ...

  9. Docker容器 关于镜像构建的安全问题

    写在前面 确保容器中服务与应用安全是容器化演进的关键点.容器安全涉及到应用开发与维护的整个生命周期,本文主要从镜像构建的视角来看docker容器的一些安全问题及应对措施. 一.权限管理 1.避免以容器 ...

  10. Linux centos7 scp命令

    1. 命令简介 scp(secure copy) 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令,可以在两台 Linux 主机进行复制操作 # 语法 scp [-1246BCpqr ...