流逝的是岁月,不变的是情怀.
坚持学习,是为了成就更好的自己.
公众号[中关村程序员]

# Docker容器数据卷

# 是什么

先看看docker的理念:

  • 将运用与运行的环境打包形成容器运行,运行可以伴随着容器,但是我们对数据的要求希望是持久化的
  • 容器之间有可能共享数据

Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据作为镜像的一部分保存下来,那么当容器删除后,数据自然也就没有了

为了能保存数据在docker中我们使用卷

一句话类似redis里面的rdb 和aof文件

# 能干嘛

卷就是目录或文件,存在与一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过UnionFS,提供一些用于存储或共享数据的特征

卷的设计目标就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷

特点:

  • 数据卷可在容器之间共享或重用数据
  • 卷的更改可以直接生效
  • 数据卷中的更改不会包含在镜像的更新中
  • 数据卷的生命周期一直持续到没有容器使用它为止

# 数据卷

# 容器内添加

1.直接命令添加

docker run -it -v /宿主机绝对路径目录:/容器内目录  镜像名

例子:

[root@laptop docker]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
centos latest 0f3e07c0138f 6 weeks ago 220MB

[root@laptop docker]#  mkdir /myDataVolume
[root@laptop docker]# docker run -it -v /myDataVolume:/dataVolumeContainer centos
[root@f71c79781ee3 /]# ls
bin dev home lib64 media opt root sbin sys usr
dataVolumeContainer etc lib lost+found mnt proc run srv tmp var


[root@laptop /]# ls
bin dudir.sh lib media oprofile_data root shares @System.solv var
boot etc lib64 mnt opt run srv tmp zookeeper_server.pid
dev home lost+found myDataVolume proc sbin sys usr

2.查看数据卷是否挂载成功

[root@laptop ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
f71c79781ee3 centos "/bin/bash" 2 minutes ago Up 2 minutes friendly_lehmann

[root@laptop ~]# docker inspect f71c79781ee3
....
"HostConfig": {
"Binds": [
"/myDataVolume:/dataVolumeContainer"
],
....



"Mounts": [
{
"Type": "bind",
"Source": "/myDataVolume",
"Destination": "/dataVolumeContainer",
"Mode": "",
"RW": true,
"Propagation": "rprivate"
}
],
...

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

4.容器停止退出后,主机修改后数据是否同步 -- 经过测试数据是同步的

5.命令

docker run -it -v /宿主机绝对路径目录:/容器内目录:ro  镜像名   #ro 只读
容器内不能写,宿主机可以写

# DockerFile添加

[root@laptop mydocker]# cat dockerfile

FROM centos
VOLUME ["/dataVolumeContainer1", "/dataVolumeContainer2"]
CMD echo "finished"
CMD /bin/bash
[root@laptop mydocker]# docker build -f dockerfile -t abc/centos .

Sending build context to Docker daemon 2.048kB
Step 1/4 : FROM centos
---> 0f3e07c0138f
Step 2/4 : VOLUME ["/dataVolumeContainer1", "/dataVolumeContainer2"]
---> Running in 97ffe5299e14
Removing intermediate container 97ffe5299e14
---> f47d556c8f0a
Step 3/4 : CMD echo "finished"
---> Running in 4bada4dcb5b5
Removing intermediate container 4bada4dcb5b5
---> 23d47518f485
Step 4/4 : CMD /bin/bash
---> Running in 9d7b4e16c397
Removing intermediate container 9d7b4e16c397
---> 0760a8000e5d
Successfully built 0760a8000e5d
Successfully tagged abc/centos:latest
[root@laptop mydocker]# docker images

REPOSITORY TAG IMAGE ID CREATED SIZE
abc/centos latest 0760a8000e5d 8 seconds ago 220MB
abc/mytomcat 1.2 f73b412690d6 About an hour ago 507MB
tomcat latest 882487b8be1d 3 weeks ago 507MB
centos latest 0f3e07c0138f 6 weeks ago 220MB


[root@laptop mydocker]# docker run -it abc/centos

[root@59f466af5f6b /]# ls -l

total 56
lrwxrwxrwx 1 root root 7 May 11 2019 bin -> usr/bin
drwxr-xr-x 2 root root 4096 Nov 15 04:24 dataVolumeContainer1
drwxr-xr-x 2 root root 4096 Nov 15 04:24 dataVolumeContainer2
...

宿主机目录路径:

[root@laptop mydocker]# docker ps

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
59f466af5f6b abc/centos "/bin/sh -c /bin/bash" 2 minutes ago Up 2 minutes sleepy_shaw
[root@laptop mydocker]# docker inspect 59f466af5f6b

"Volumes": {
"/dataVolumeContainer1": {},
"/dataVolumeContainer2": {}
....
]

# 数据卷容器

# 是什么

命名的容器挂载数据卷,其它容器通过挂载这个实现数据共享,挂载数据卷的容器,称之为数据卷容器

/dataVolumeContainer1
/dataVolumeContainer2

# 容器之间传递共享

--volumes-from
docker run -it xxx --volumes-from xxx  xxxx

容器之间配置信息的传递,数据卷的的生命周期一直持续到没有容器使用它为止

上次更新: 7/20/2020, 2:09:44 AM