2. volume解惑

简介: Volume解惑docker是一个容器,在容器中执行的所有操作都会在容器exit后丢失,为了保证数据的持久化,docker提出了volume的概念,目的是将容器中的数据持久化到宿主机中。docker可以使用两种方法来创建volume,一种是创建容器时使用-v参数,另一种是创建镜像的时候在Dockerfile文件中设置volume。

Volume解惑

docker是一个容器,在容器中执行的所有操作都会在容器exit后丢失,为了保证数据的持久化,docker提出了volume的概念,目的是将容器中的数据持久化到宿主机中。
docker可以使用两种方法来创建volume,一种是创建容器时使用-v参数,另一种是创建镜像的时候在Dockerfile文件中设置volume。

下面来看看这两种方式的区别:

1. 在Dockerfile创建Volume

Dockerfile

FROM daocloud.io/centos:latest
//这里指定要在容器中挂载test1和test2目录,这里有一点需要注意一定要使用双引号
VOLUME ["/test1","/test2"]
CMD /bin/bash

编译Dockerfile

mkdir test
mv Dockerfile test/
cd test
docker build . -t test

从上一步生成的镜像中创建一个容器:

//这里创建一个名为test1的容器
docker run -it --name test-container test

查看容器中生成的test1和test2目录与物理磁盘的对应关系

docker inspect test-container

//运行结果如下:其中Source指向的就是宿主机的目录
....
"Mounts": [
    {
        "Type": "volume",
        "Name": "01c6e11009f3a1382dc71715a2ecc810e6854a817fbaf47887ae361e1444135c",
        "Source": "/var/lib/docker/volumes/01c6e11009f3a1382dc71715a2ecc810e6854a817fbaf47887ae361e1444135c/_data",
        "Destination": "/test1",
        "Driver": "local",
        "Mode": "",
        "RW": true,
        "Propagation": ""
    },
    {
        "Type": "volume",
        "Name": "3f86f47f6dac9a3bf1a0967aee3f424db27c4dd5d48bd746b7692592085f0f25",
        "Source": "/var/lib/docker/volumes/3f86f47f6dac9a3bf1a0967aee3f424db27c4dd5d48bd746b7692592085f0f25/_data",
        "Destination": "/test2",
        "Driver": "local",
        "Mode": "",
        "RW": true,
        "Propagation": ""
    }
],
.....

2. 使用-v参数来创建volume

Dockerfile

FROM daocloud.io/centos:latest
CMD /bin/bash

编译Dockerfile

mkdir test
mv Dockerfile test/
cd test
docker build . -t test-new

从上一步生成的镜像创建容器:

docker run -it -v /test1 -v /test2 --name test-container-new test-new

查看容器中生成的test1和test2目录与物理磁盘的对应关系

docker inspect test-container-new

//运行结果如下:其中Source指向的就是宿主机的目录
....
"Mounts": [
    {
        "Type": "volume",
        "Name": "2c8d289d74801a10f2ec283e83412541009d9fb7d40aec161e8c363b17d6e822",
        "Source": "/var/lib/docker/volumes/2c8d289d74801a10f2ec283e83412541009d9fb7d40aec161e8c363b17d6e822/_data",
        "Destination": "/test1",
        "Driver": "local",
        "Mode": "",
        "RW": true,
        "Propagation": ""
    },
    {
        "Type": "volume",
        "Name": "a0905219edf3ad76be39065598f5443d9230f72a8e2e650d98c4f982b87d952d",
        "Source": "/var/lib/docker/volumes/a0905219edf3ad76be39065598f5443d9230f72a8e2e650d98c4f982b87d952d/_data",
        "Destination": "/test2",
        "Driver": "local",
        "Mode": "",
        "RW": true,
        "Propagation": ""
    }
],
.....

通过两种方式发现虽然都在宿主机上生成了持久化目录,但是宿主机的目录都是随机的

-v参数高级用法,在宿主机生成自定义持久目录

从上一步生成的镜像创建容器:

docker run -it -v /test1:/test1 -v /test2:/test2 --name test-container-new-2 test-new

查看容器中生成的test1和test2目录与物理磁盘的对应关系

docker inspect  test-container-new-2 

//运行结果如下:其中Source指向的就是宿主机的目录
....
"Mounts": [
    {
        "Type": "bind",
        "Source": "/test1",
        "Destination": "/test1",
        "Mode": "",
        "RW": true,
        "Propagation": ""
    },
    {
        "Type": "bind",
        "Source": "/test2",
        "Destination": "/test2",
        "Mode": "",
        "RW": true,
        "Propagation": ""
    }
],
.....

两种创建volume方法的总结

创建Volume的两种方式 随机目录持久化 指定目录持久化
Dokerfile VOLUME 可以实现 不支持
-v参数 可以实现 支持
目录
相关文章
|
3月前
|
存储 Kubernetes 开发工具
Kerbernetes的volume应用进阶
关于Kubernetes中持久卷(PV)和持久卷声明(PVC)应用进阶的教程,涵盖了PV和PVC的基本概念、存储访问模式、回收策略、生命周期,以及如何通过实战案例在Kubernetes集群中使用NFS和动态供给创建和管理持久化存储。
29 1
Kerbernetes的volume应用进阶
|
3月前
|
存储 Kubernetes 开发工具
Kerbernetes的volume基础应用
关于Kubernetes存储卷(Volume)基础应用的教程,涵盖了存储卷的概述、Kubernetes内置存储卷类型、使用注意事项、本地存储卷案例、临时存储卷案例、网络存储案例以及其他存储案例,并提供了相应的命令和配置文件示例。
51 0
Kerbernetes的volume基础应用
|
存储 Kubernetes 应用服务中间件
大白话说明白K8S的PV / PVC / StorageClass(理论+实践)
本文主要通过大白话说明白PV、PVC的概念和原理,再说说StorageClass的作用,最后通过实践加深理解。
大白话说明白K8S的PV / PVC / StorageClass(理论+实践)
|
存储 Kubernetes API
k8s教程(Volume篇)-动态存储管理案例(GlusterFS)
k8s教程(Volume篇)-动态存储管理案例(GlusterFS)
262 0
|
前端开发
前端工作总结189-storage区别
前端工作总结189-storage区别
58 0
前端工作总结189-storage区别
|
存储 缓存 运维
Gluster vs Ceph:开源存储领域的正面较量
开源的Ceph及Red Hat旗下的Gluster都是成熟的技术,但兴许不久之后就将经历某种重生了。随着存储产业开始向扩展性存储及云的方向发展,将不断会有基于这些低价的软件技术的产品推向市场,而对这些自集成解决方案的补充在近一年来不断涌现。
461 0