PureFlash云原生存储
PureFlash是一个开源存储系统,它能为云计算和传统应用提供块存储服务。PureFlash最显著的优势是其高性能,每节点能提供超过100万IOPS随机写IO。
PureFlash可以以云原生的方式部署,并为云原生应用提供持久存储。
PureFlash存储系统简介:https://blog.csdn.net/winux/article/details/114436250
PureFlash的开源项目位置:https://github.com/cocalele/PureFlash
PureFlash-csi项目作为k8s插件,位置在:https://github.com/cocalele/pureflash-csi.git
这个项目提供下面的功能:
- 使用yaml文件在k8s集群中部署PureFlash服务
- 提供CSI插件,以为k8s集群中的其他应用提供PV服务
本文介绍在K8S系统中部署PureFlash的步骤方法。
前提准备工作
从github 或者 gitee获取本项目代码:
# git clone https://gitee.com/cocalele/pureflash-csi.git
or
# git clone https://github.com/cocalele/pureflash-csi.git
部署存储服务
这一步可以在你的k8s集群中部署PureFlash. 就像其他的云原生存储(比如openEBS)一样,PureFlash把物理盘转变成软件定义存储服务。同时提供包括精简置备、快照、多副本、高可用等能力。
-
修改
pfs-cluster/deploy/pfs.yaml
这个文件中的PFS_DISKS
变量,让他和实际的NVMe盘名字相同。- name: PFS_DISKS value: "/dev/nvme1n1,/dev/nvme2n1"
物理盘需要是干净的没有任何数据,接下来物理盘将被PureFlash管理,上面原有的数据会被丢弃。
-
依次应用下面的 yaml 文件:
# kubectl apply -f pfs-cluster/deploy/namespace.yaml # kubectl apply -f pfs-cluster/deploy/pfzk.yaml # kubectl apply -f pfs-cluster/deploy/pfdb.yaml # kubectl apply -f pfs-cluster/deploy/pfc.yaml # kubectl apply -f pfs-cluster/deploy/pfs.yaml
请在执行每一条命令前检查pod的状态都是正常的,即,前一条命令的执行完全成功。
上面命令执行完成后,存储服务就部署完了。
部署 CSI 插件
CSI插件是为了让K8s里面的应用程序能够访问存储服务提供的存储。
应用下面的yaml 文件:
# kubectl apply -f deploy/rbac-csi-pfbd.yaml
# kubectl apply -f deploy/csi-pfbd-driverinfo.yaml
# kubectl apply -f deploy/csi-pfbd-controller.yaml
# kubectl apply -f deploy/csi-pfbd-node.yaml
PureFlash CSI 使用原生的内核态驱动作为客户端接口。内核驱动将数据卷以标准块设备的形式呈现在Linux系统里。这样就可以兼容任意的用户态应用。原生的内核态驱动也具有更高的性能,以及完整的PureFlash数据卷功能。
对应内核版本的驱动都放在项目的modules
下面。更多内核版本的支持正在不断加入到里面。
在创建PV前,请在host系统里面 运行命令 insmod pfkd-$(uname -r).ko
安装驱动。
创建使用PureFlash的 storage class
请参照项目examples目录里的这个文件:
# cat examples/sc.yaml
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
name: pfbd-rep2
provisioner: pfbd.csi.pureflash
reclaimPolicy: Delete
volumeBindingMode: WaitForFirstConsumer
allowVolumeExpansion: true
parameters:
replica_count: "2"
kubectl apply -f examples/sc.yaml
这个命令创建一个2副本volume的SC
kubectl apply -f examples/my-busybox.yaml
这个命令启动一个容器,使用上述SC的PVC.