• 作者:老汪软件技巧
  • 发表时间: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 中。

(关注我,无广告,专注于技术,不煽动情绪)

参考资料: