K8s 数据存储之Volume

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了K8s 数据存储之Volume相关的知识,希望对你有一定的参考价值。

参考技术A 一切container和它之中的数据都是临时的。如果container重启,这些数据会丢失。Volume用于container保存需要持久化的数据。这些数据也可以用于container共享。

Docker中有volume的概念。在Docker中,volume是container中的一个目录。Volume没有生命周期的概念,volume中的数据只有储存在本地磁盘这一种形式。

Kubernetes的volume具有明确的生命空间。Volume生命周期比pod中运行的container长。Container重启之后,volume的数据仍会保留。但是,当Pod销毁之时,该pod关联的volume也会同时销毁。

使用volume的方法:在spec.volumes处声明volume,在spec.containers[*].volumeMount中挂载volume到container。

可以将ConfigMap的值注入到volume中。这样可以在pod中使用config map。同时,Volume中的值会随着ConfigMap的修改而自动更新。

在Volume中使用ConfigMap的用法如下:

这里例子将名字为log-config的config map中key为log_level的值,作为文件log_level的内容,放入config-vol的根目录。然后把config-vol挂载到 /etc/config ,目录。也就是container中 /etc/config/log_level 文件的内容为log-config中log_level的值。

可以使用DownWard API的方式,将k8s资源的spec信息作为文件内容放入到volume中。

例子如下:

此处volume使用了downwardAPI。volume中labels文件的内容为pod metadata的labels配置项内容,即:

annotation文件的内容为为pod metadata的annotations配置项内容,即:

生命周期和pod一样。emptyDir的初始状态为一个没有任何内容的volume。如果Pod从集群节点上移除,那么emptyDir类型的volume中的内容会被清除。

Container遇到崩溃或重启,这时候Pod本身不会受任何影响,这种情况下emptyDir volume中的数据会保留。Container重启之后数据仍然可见。

emptyDir volume具有的这种特性适合如下场景使用:

默认来说emptyDir类型volume的物理存储在硬盘,SSD或网络设备上。可以设置 emptyDir.medium 为 Memory ,这时候k8s会使用tempfs(基于内存的文件系统)。此时volume的容量限制收到container的内存配额的制约。

配置样例为:

使用tempfs(内存)的emptyDir volume的配置样例如下;

gitRepo比较简单:先准备一个emptyDir类型的volume,再clone一个git repo到volume,然后把volume mount到container。

此模式挂载pod宿主机文件系统中的文件或目录到pod。

hostPath必须指定一个path参与,用于指定使用宿主机哪个目录。

除此之外还有一个可选的type参数,有如下值可供配置:

需要注意的是由于hostPath类型volume的数据和宿主机强绑定,如果pod停止后被schedule到其他节点,pod读取到的数据会有变化。

使用hostPath的例子:

local模式支持使用磁盘,分区或者是目录。local还支持使用静态创建的PersistentVolume,不支持Dynamic provisioning(使用PVC的方式)。

与hostPath不同的是,local模式无需手动配置将pod调度到固定的node上。local模式系统通过volume的node affinity配置来感知volume的node限制(volume只能生成在特定的node上)。

使用例子:

nodeAffinity必须配置。这个例子创建出的PersistentVolume必须创建在hostname包含 example-node 的节点上。

VolumeMode默认值为Filesystem。可以配置为 Block ,将volume作为块设备使用。

使用local模式的时候建议配套的StorageClass的 volumeBindingMode 设置为 WaitForFirstConsumer 。如下所示:

延迟volume绑定可以允许在volume绑定的时候考虑到pod中配置的一些限制,例如node资源限制,node选择器和pod affinity以及pod anti-affinity。

使用PVC声明式的创建所需的PersistentVolume。这个稍后在PersistentVolume中介绍。

映射多个类型的配置(数据源)到volume中。相当于多种volume合并使用。

可以映射的volume类型为:

所有的volume数据源要求必须和使用它的pod在同一个namespace之下。

一个使用例子如下:

通常我们绑定volume时,映射的是volume的根目录。我们可以通过指定subPath参数,将volume中的其他目录挂载到container中。对于一个pod多个container,且多处使用同一个volume的场景最为适用。

例子如下:

这个例子中mysqlphp两个container使用同一个volume site-data。Volume的 mysql 目录映射到了mysql container的 /var/lib/mysql 。Volume的 html 目录映射到了php container的 /var/www/html 。

emptyDir使用磁盘时的限制取决于kubelet所在的文件系统(/var/lib/kubelet)。emptyDir或者hostPath占用多大磁盘空间是没有限制的。

以上是关于K8s 数据存储之Volume的主要内容,如果未能解决你的问题,请参考以下文章

k8s之volumes持久化存储

云原生kubernetesk8s数据存储之Volume使用详解

k8s 存储卷之简单存储

k8s 存储卷之简单存储

19,k8s 之 Volume

Kubernetes K8S之存储Volume详解