Docker数据管理

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

  • 数据卷(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

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,064评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,606评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,011评论 0 328
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,550评论 1 269
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,465评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,919评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,428评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,075评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,208评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,185评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,191评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,914评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,482评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,585评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,825评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,194评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,703评论 2 339