- 作者:老汪软件技巧
- 发表时间:2024-10-01 04:02
- 浏览量:
本文将会以 CSI driver - NFS 为例,讲述 CSI 驱动的工作流程和原理。
CSI 概述
CSI 驱动通常分为两个部分:
CSI 与 kubernetes 组件的交互:
由于交互的通用性,为了简化 CSI 驱动程序的开发,社区提供了很多 CSI Sidecar Containers,包括上图中的:
除此 Sidecar 之外还有:
CSI 使用过程
1. CSI 驱动准备阶段
确保集群中已正确安装 CSI 驱动,通常:
安装完成后,Controller plugin 会向 kube-api-server 监听相关的资源对象,Node plugin 则会向 kubelet 注册自己。
2. 卷的动态配置
集群管理员创建 StorageClass 对象来声明存储类型。
用户创建 PVC 对象并指定 StorageClass,此时 Controller plugin 中的:
3. 创建 Pod 并使用卷
用户创建 Pod 并使用卷。
kube-api-server 接受到请求,kube-scheduler 将 Pod 调度到节点上。
该节点上的 kubelet 向 Node plugin 发起 gRPC NodePublishVolume 调用,由 Node plugin 中的 nfs-driver(具体的 CSI 驱动程序)完成文件目录的挂载。
至此,Pod 中的应用程序便可以使用挂载好的文件目录了,就像使用本地文件系统一样。
然而,Pod 中的应用程序实际操作的却是 NFS 远程共享目录,这又是怎么做到的?
Linux VFS
Linux 在实际的文件系统之上,其实还有一层 VFS(virtual filesystem)虚拟文件系统。
VFS 是一个抽象层,它允许应用程序通过统一的系统调用来操作不同类型的文件系统。无论是本地文件系统还是远程文件系统(如 NFS),操作都经过 VFS 中转。对于挂载了 NFS 目录的系统,VFS 会将相应的系统调用转交给 NFS 客户端,NFS 客户端则使用 RPC 网络通信与 NFS 服务器进行交互。
总结
除了 NFS 之外,CephFS 等其他分布式存储系统也采用了类似的工作原理和流程。
CSI 定义了标准化的 gRPC 协议,以及 CSI 驱动的交互过程和架构,使得各种存储系统可以通过统一的接口集成到 Kubernetes 中。
(关注我,无广告,专注于技术,不煽动情绪)
参考资料: