美文网首页
Docker数据管理

Docker数据管理

作者: 泓落飞涯 | 来源:发表于2019-07-22 19:06 被阅读0次

容器中的管理数据主要有两种方式:

  • 数据卷(Data Volumes): 容器内数据直接映射到本地主机环境;
  • 数据卷容器(Data Volume Containers): 使用特定容器维护数据卷。

1.数据卷

数据卷(Data Volumes)是一个可供容器使用的特殊目录,它将主机操作系统目录直接
映射进容器,类似于Linux中的mount行为。

数据卷可以提供很多有用的特性:

  • 数据卷可以在容器之间共事和重用,容器间传递数据将变得高效与方便;
  • 对数据卷内数据的修改会立马生效,无论是容器内操作还是本地操作;
  • 对数据卷的更新不会影响镜像,解摘开应用和数据
  • 卷会一直存在,直到没有容器使用,可以安全地卸载它

1.1 创建数据卷

创建命令:

docker volume create -d local test

-d的意思是:Specify volume driver name (default "local")

此时,查看/var/lib/docker/volumes 路径下,会发现所创建的数据卷位置:

[root@localhost ~]# ll /var/lib/docker/volumes/   
total 24
-rw-------. 1 root root 32768 Jul 22 17:59 metadata.db
drwxr-xr-x. 3 root root    19 Jul 22 17:59 test

# metadata.db是一个volumes的元数据库文件,不用管它

查看数据卷的详细信息:

[root@localhost ~]# docker volume inspect test  
[
    {
        "CreatedAt": "2019-07-22T17:59:37+08:00",
        "Driver": "local",
        "Labels": {},
        "Mountpoint": "/var/lib/docker/volumes/test/_data",
        "Name": "test",
        "Options": {},
        "Scope": "local"
    }
]

volume除了以上介绍的子命令外,还有ls(列出已有数据卷)、prune(清理无用数据卷)、rm(删除数据卷)等。

1.2 绑定数据卷

除了使用 volume 子命令来管理数据卷外,还可以在创建容器时将主机本地的任意路径挂载到容器内作为数据卷,这种形式创建的数据卷称为绑定数据卷。

在用docker [container] run命令的时候,可以使用-mount选项来使用数据卷。

-mount选项支持三种类型的数据卷,包括:

  • volume:普通数据卷,映射到主机/var/lib/docker/volumes路径下;
  • bind:绑定数据卷,映射到主机指定路径下;
  • tmpfs:临时数据卷,只存在于内存中。

下面演示这三种操作示例:

1.2.1 volume

1.创建一个数据卷

docker volume create -d local test

2.启动容器,并绑定该数据卷:

docker run -it --mount type=volume,source=test,destination=/opt centos /bin/bash

该命令可以简写为(老版写法):
docker run -it -v test:/opt centos /bin/bash

3.在容器内部创建一个文件,并编辑信息:

[root@3a99d6382de8 /]# cd /opt/                                                        
[root@3a99d6382de8 opt]# echo hello >> a.txt 
[root@3a99d6382de8 opt]# cat a.txt 
hello

4.在本地操作系统查看该路径的变化:/var/lib/docker/volumes/test/_data

[root@localhost _data]# cd /var/lib/docker/volumes/test/_data/
[root@localhost _data]# ls
a.txt
[root@localhost _data]# cat a.txt 
hello

5.在本地操作系统/var/lib/docker/volumes/test/_data路径下创建一个文件,并编辑信息:

[root@localhost _data]# echo docker >> b.txt
[root@localhost _data]# cat b.txt 
docker
[root@localhost _data]# ls
a.txt  b.txt

6.进入到docker容器中,查看/opt:

[root@3a99d6382de8 opt]# ls
a.txt  b.txt
[root@3a99d6382de8 opt]# cat b.txt 
docker

该示例说明了:本地操作系统数据卷和容器内的数据挂载点是双向互通联动的,一端改动另一端也会跟着改动。

1.2.2 bind

1.启动容器,并与主机某个目录绑定:

docker run -it --mount type=bind,source=/opt/data/test,destination=/opt centos /bin/bash

该命令可以简写为(老版写法):
docker run -it -v /opt/data/test:/opt centos /bin/bash

注意:/opt/data/test必需要先创建好。

  1. 在容器/opt目录下创建文件,并编辑内容:
[root@a6f3b85a996e /]# cd /opt/
[root@a6f3b85a996e opt]# echo hello >> a.txt 
[root@a6f3b85a996e opt]# cat a.txt 
hello
  1. 在主机/opt/data/test路径进行查看:
[root@localhost test]# cd /opt/data/test/ && ll
total 4
-rw-r--r--. 1 root root 6 Jul 22 18:35 a.txt
[root@localhost test]# cat a.txt 
hello
  1. 在主机/opt/data/test路径创建文件,并编辑内容:
[root@localhost test]# echo docker >> b.txt
[root@localhost test]# ls
a.txt  b.txt
  1. 在容器/opt目录下进行查看:
[root@a6f3b85a996e opt]# ls   
a.txt  b.txt
[root@a6f3b85a996e opt]# cat b.txt 
docker

该示例说明了:本地操作系统数据目录和容器内的数据挂载点是双向互通联动的,一端改动另一端也会跟着改动。

1.2.3 tmpfs

2.数据卷容器

如果用户需要在多个容器之间共享一些持续更新的数据,最简单的方式是使用数据卷容器。数据卷容器也是一个容器,但是它的目的是专门提供数据卷给其他容器挂载。

  1. 创建一个数据卷容器,并在启动创建数据卷挂载到/opt/data:
docker run -it -v /opt/data --name data-volume --hostname data-volume centos

此处的/opt/data指的是容器内的挂载点,不是主机的。

  1. 可以在其他容器启动时使用--volumes-from来挂载data-volume容器中的数据卷,例如:
docker run -it --volumes-from data-volume --name web --hostname web centos
  1. 在web容器的/opt/data目录下新建文件,并编辑内容:
[root@web /]# cd /opt/data/                                   
[root@web data]# echo hello >> a.txt
[root@web data]# cat a.txt 
hello
  1. 在数据卷容器的/opt/data目录下进行查看:
[root@data-volume data]# cd /opt/data/ && ls
a.txt
[root@data-volume data]# cat a.txt 
hello
  1. 在数据卷容器的/opt/data目录下新建文件,并编辑内容:
[root@data-volume data]# echo docker >> b.txt 
[root@data-volume data]# ls
a.txt  b.txt
  1. 在web容器的/opt/data目录下进行查看:
[root@web data]# ls   
a.txt  b.txt
[root@web data]# cat b.txt 
docker

该示例说明了:数据卷容器和使用该数据卷容器的容器的数据挂载点是双向互通联动的,一端改动另一端也会跟着改动。

相关文章

  • 39-docker(一)

    本章内容 ◆ Docker简介◆ Docker 镜像与制作◆ Docker 数据管理◆ Docker 网络◆ Do...

  • docker(三)docker镜像文件

    数据管理前提1>docker容器不应该负责持久化2>业界使用docker,等价于使用服务3>官方使用docker,...

  • docker 镜像与容器

    Docker中通过模板创建镜像,Docker容器、仓库及数据管理[https://blog.51cto.com/f...

  • Docker的那些事儿—Docker数据管理(28)

    从本节开启Docker存储部分,学习docker是如何对数据管理的。 上一篇:Docker的那些事儿—容器与外部网...

  • Docker学习五、docker容器数据卷

    前言、Docker中的数据管理 Docker镜像是由多个只读层叠加而成,启动容器时,Docker会加载只读层并会在...

  • Docker基本命令

    镜像操作相关命令 容器操作相关命令 访问Docker仓库 Docker数据管理 端口映射与容器互联 Dockerf...

  • Docker 入门教程之数据管理

    Docker 数据管理的方式 Docker 对于容器数据的存储推荐挂载到宿主机,以此减轻容器的大小,也方便数据和容...

  • Docker数据管理

    容器管理数据方式: 数据卷:容器内数据直接映射到本地主机环境; 数据卷容器:使用特定容器维护数据卷。 数据卷 类似...

  • docker数据管理

    容器添加数据卷 数据卷添加权限 ro-read-only 只读rw-read-write 写读 dockerfil...

  • Docker 数据管理

    容器中管理数据主要有两种方式: 数据卷(Data Volumes) 数据卷容器(Data Volume Conta...

网友评论

      本文标题:Docker数据管理

      本文链接:https://www.haomeiwen.com/subject/vwhglctx.html