k8s-持久化存储,粗浅学习

k8s存储类:storageclass

Kubernetes提供一种自动创建PV的机制,叫StorageClass ,它的作用就是创建PV的模板。k8s集群管理员通过创建storageclass可以动态生成一个存储卷pv供k8s pvc使用。

每个StorageClass都包含字段provisioner,parameters和reclaimPolicy。

具体来说,StorageClass会定义以下两部分:

1、PV的属性 ,比如存储的大小、类型等;

2、创建这种PV需要使用到的存储插件,比如Ceph、NFS等

有了这两部分信息,Kubernetes就能够根据用户提交的PVC,找到对应的StorageClass,然后Kubernetes就会调用 StorageClass声明的存储插件,创建出需要的PV。

volumeClaimTemplates实现了pvc的自动化,StorageClass实现了pv的自动化

每个 StorageClass 都包含 provisioner、parameters 和 reclaimPolicy 字段, 这些字段会在 StorageClass 需要动态分配 PersistentVolume 时会使用到

StorageClass对象的命名很重要,用户使用这个命名来请求生成一个特定的类。当创建 StorageClass对象时,管理员设置 StorageClass 对象的命名和其他参数,一旦创建了对象就不能再对其更新

管理员可以为没有申请绑定到特定 StorageClass 的 PVC 指定一个默认的存储类

要使用 StorageClass,我们就得安装对应的自动配置程序,比如我们这里存储后端使用的是 nfs,那么我们就需要使用到一个 nfs-client 的自动配置程序,我们也叫它 Provisioner(制备器),这个程序使我们已经配置好的 nfs 服务器,来自动创建持久卷,也就是自动帮我们创建 PV。

**搭建StorageClass+NFS,大致有以下几个步骤: **

1.创建一个可用的NFS Serve(实际存储文件的空间)

2.创建Service Account 这是用来管控NFS provisioner在k8s集群中运行的权限

3.创建StorageClass 负责建立PVC并调用NFS provisioner进行预定的工作,并让PV与PVC建立管理

4.创建NFS provisioner(存储制备器)

1)每个 StorageClass 都有一个制备器(Provisioner)用来决定使用哪个卷插件制备 PV。 该字段必须指定。

2)主要有两个功能

一个是在NFS共享目录下创建挂载点(volume)

另一个则是建了PV并将PV与NFS的挂载点建立关联

安装nfs provisioner,用于配合存储类动态生成pv

创建运行nfs-provisioner需要的sa账号

vim /root/newfs/sa.yml

cd /root/newfs

执行 kubectl apply -f sa.yml

后台持久运行nfs: systemctl enable --now nfs (详情请看持久化存储上一章中的nfs)

重新加载 NFS 共享配置,并输出详细日志:exportfs -arv

创建storageclass,动态供给pv

vim provisioner.yml​​​​​​​

执行kubectl apply -f provisioner.yml

vim storage.yml

kubectl apply -f storage.yml

vim pvc.yaml

kubectl apply -f pvc.yaml

kubectl get pv

kubectl get pvc

vim pod.yml

在共享目录创建成功

验证写入成功

相关推荐
XGeFei16 小时前
【Fastapi学习笔记(3)】——资源的层级关系、安全性-幂等性、Field、工厂函数
笔记·学习·fastapi
逍遥德16 小时前
MQTT教程详解-04.SpringBoot集成MQTT(告别手动控制)
java·spring boot·物联网·中间件·iot·iotdb
语戚16 小时前
力扣 3161. 块放置查询:线段树解法(Java 实现)
java·算法·leetcode·面试·线段树·力扣·
我命由我1234517 小时前
Android 开发问题:MlKitException: An internal error occurred during initialization.
android·java·java-ee·android jetpack·android-studio·androidx·android runtime
星恒随风17 小时前
Python 基础语法详解(一):从表达式、变量到数据类型
开发语言·笔记·python·学习
888CC++17 小时前
java 并发编程
java·开发语言·python
无风听海17 小时前
JSON Web Token(JWT)完全指南
java·前端·json
JAVA社区18 小时前
Java高级全套教程(十一)—— Kubernetes 超详细企业级实战详解
java·运维·微服务·容器·面试·kubernetes
tedcloud12318 小时前
cc-switch评测:多AI Coding Agent管理工具详解
数据库·人工智能·sql·学习·自动化
胡图图不糊涂^_^19 小时前
测试BUG篇
学习·bug·测试