当前位置:   article > 正文

k8s持久化存储之OpenEBS

openebs

一、介绍

OpenEBS 是 CNCF 项目的一部分,采用 Apache v2 许可证。是 Kubernetes 部署使用最广泛且易用的开源存储解决方案。

目的:

持久化工作负载的存储和存储服务完全集成到环境中,这样每个团队和工作负载都可以从控制的粒度和 Kubernetes 原生行为中获益。

特点:

  • 微服务架构,使用 Kubernetes 自身的能力来编排管理 OpenEBS 组件。
  • OpenEBS 支持一系列存储引擎,以便开发人员能够部署适合其应用程序设计目标的存储技术。像 Cassandra 这样的分布式应用程序可以使用 LocalPV 引擎实现最低延迟的写操作。像 MySQL 和 PostgreSQL 这样的独立应用程序可以使用 ZFS 引擎 (cStor) 进行恢复。像 Kafka 这样的流媒体应用程序可以使用 NVMe 引擎 Mayastor 在边缘环境中获得最佳性能。
  • 在各种引擎类型中,OpenEBS 为高可用性、快照、克隆和易管理性提供了一致的框架。
  • 管理员和开发人员可以使用 Kubernetes 提供的所有工具来交互和管理 OpenEBS。

二、OpenEBS 存储引擎建议

应用需求存储类型OpenEBS 卷类型
低时延、高可用性、同步复制、快照、克隆、精简配置SSD/ 云存储卷OpenEBS Mayastor
高可用性、同步复制、快照、克隆、精简配置机械 /SSD/ 云存储卷OpenEBS cStor
高可用性、同步复制、精简配置主机路径或外部挂载存储OpenEBS Jiva
低时延、本地 PV主机路径或外部挂载存储Dynamic Local PV - Hostpath, Dynamic Local PV - Rawfile
低时延、本地 PV本地机械 /SSD/ 云存储卷等块设备Dynamic Local PV - Device
低延迟,本地 PV,快照,克隆本地机械 /SSD/ 云存储卷等块设备OpenEBS Dynamic Local PV - ZFS , OpenEBS Dynamic Local PV - LVM
  • 多机环境,如果有额外的块设备(非系统盘块设备)作为数据盘,选用 OpenEBS MayastorOpenEBS cStor
  • 多机环境,如果没有额外的块设备(非系统盘块设备)作为数据盘,仅单块系统盘块设备,选用 OpenEBS Jiva
  • 单机环境,建议本地路径 Dynamic Local PV - Hostpath, Dynamic Local PV - Rawfile,由于单机多用于测试环境,数据可靠性要求较低。

三、安装

openobs官方安装文档

在安装openebs之前先去除污点,然后等安装完成再添加回来污点

  1. # 去除污点
  2. kubectl taint nodes k8s-master01 node-role.kubernetes.io/master=:NoSchedule-
  3. # 添加污点
  4. kubectl taint nodes k8s-master01 node-role.kubernetes.io/master=:NoSchedule

添加helm repo

  1. helm repo add openebs https://openebs.github.io/charts
  2. helm repo update

安装openebs(这里只会安装Jiva和Local组件)

helm install openebs --namespace openebs openebs/openebs --create-namespace --version 3.0.x

添加cstor支持

helm install openebs --namespace openebs openebs/openebs --create-namespace --set cstor.enabled=true --version 3.2.0

查看安装

  1. # 查看安装pod
  2. kubectl get pod -n openebs
  3. # 查看安装blockdevice,这里的blockdevice是磁盘,当添加一块未分配的磁盘,就会有值
  4. kubectl get bd -n openebs

OpenEBS依赖与iSCSI做存储管理,因此需要先确保您的集群上已有安装openiscsi。 (这里当报错的时候可以安装试试)

  1. yum -y install iscsi-initiator-utils
  2. systemctl enable iscsid --now
  3. systemctl start iscsid

查看安装状况:

  1. [root@k8s-master01 ~]# kubectl get pod -n openebs
  2. NAME READY STATUS RESTARTS AGE
  3. openebs-cstor-admission-server-b74f5487-lkz84 1/1 Running 1 (6m21s ago) 8h
  4. openebs-cstor-csi-controller-0 6/6 Running 0 4m44s
  5. openebs-cstor-csi-node-4df4w 2/2 Running 2 (61m ago) 8h
  6. openebs-cstor-csi-node-x8bmt 2/2 Running 6 (16m ago) 8h
  7. openebs-cstor-csi-node-zzn4k 2/2 Running 2 (6m21s ago) 8h
  8. openebs-cstor-cspc-operator-84464fb479-fh949 1/1 Running 3 (16m ago) 8h
  9. openebs-cstor-cvc-operator-646f6f676b-xhd44 1/1 Running 2 (16m ago) 46m
  10. openebs-localpv-provisioner-55b65f8b55-zqj29 1/1 Running 13 (6m23s ago) 8h
  11. openebs-ndm-429hl 1/1 Running 2 (4m28s ago) 8h
  12. openebs-ndm-9kkzd 1/1 Running 1 (6m21s ago) 8h
  13. openebs-ndm-operator-6c944d87b6-5ddxz 1/1 Running 2 (16m ago) 46m
  14. openebs-ndm-sqnwx 1/1 Running 6 (15m ago) 8h

四、添加磁盘

  1. [root@k8s-master01 ~]# kubectl get bd -n openebs
  2. NAME NODENAME SIZE CLAIMSTATE STATUS AGE
  3. blockdevice-57886fae032a3d3638badeb1282dd67e k8s-node02 21473771008 Unclaimed Active 53s
  4. blockdevice-d923fc382d96ff6eea7d9ab8efb66224 k8s-master01 21473771008 Unclaimed Active 11m
  5. blockdevice-e5009ce419c80719025c4cc9409253ab k8s-node01 21473771008 Unclaimed Active 33s

五、配置

5.1 创建cStor存储池

cspc.yaml :

  1. apiVersion: cstor.openebs.io/v1
  2. kind: CStorPoolCluster
  3. metadata:
  4. name: cstor-disk-pool
  5. namespace: openebs
  6. spec:
  7. pools:
  8. - nodeSelector:
  9. kubernetes.io/hostname: "k8s-master01"
  10. dataRaidGroups:
  11. - blockDevices:
  12. - blockDeviceName: "blockdevice-d923fc382d96ff6eea7d9ab8efb66224"
  13. poolConfig:
  14. dataRaidGroupType: "stripe"
  15. - nodeSelector:
  16. kubernetes.io/hostname: "k8s-node01"
  17. dataRaidGroups:
  18. - blockDevices:
  19. - blockDeviceName: "blockdevice-e5009ce419c80719025c4cc9409253ab"
  20. poolConfig:
  21. dataRaidGroupType: "stripe"
  22. - nodeSelector:
  23. kubernetes.io/hostname: "k8s-node02"
  24. dataRaidGroups:
  25. - blockDevices:
  26. - blockDeviceName: "blockdevice-57886fae032a3d3638badeb1282dd67e"
  27. poolConfig:
  28. dataRaidGroupType: "stripe"

dataRaidGroupType:可以根据您的需要设置为 stripe or mirror 。下面以配置为stripe为例。

  1. [root@k8s-master01 openebs]# kubectl get CStorPoolCluster -n openebs
  2. NAME HEALTHYINSTANCES PROVISIONEDINSTANCES DESIREDINSTANCES AGE
  3. cstor-disk-pool 3 3 42s

5.2 storageclass创建

5.2.1 cstor的创建

  1. kind: StorageClass
  2. apiVersion: storage.k8s.io/v1
  3. metadata:
  4. name: cstor-csi-disk
  5. provisioner: cstor.csi.openebs.io
  6. allowVolumeExpansion: true
  7. parameters:
  8. cas-type: cstor
  9. # cstorPoolCluster should have the name of the CSPC
  10. cstorPoolCluster: cstor-disk-pool
  11. # replicaCount should be <= no. of CSPI created in the selected CSPC
  12. replicaCount: "3"

添加硬盘后查看磁盘情况

  1. 磁盘 /dev/sdb:21.5 GB, 21474836480 字节,41943040 个扇区
  2. Units = 扇区 of 1 * 512 = 512 bytes
  3. 扇区大小(逻辑/物理):512 字节 / 512 字节
  4. I/O 大小(最小/最佳):512 字节 / 512 字节
  5. 磁盘标签类型:gpt
  6. Disk identifier: ADA9C10B-8C31-4EE2-A29B-F2701E9554DC
  7. # Start End Size Type Name
  8. 1 2048 41943006 20G Linux filesyste OpenEBS_NDM

5.2.2 jiva

  1. apiVersion: storage.k8s.io/v1
  2. kind: StorageClass
  3. metadata:
  4. name: jiva-storageclass
  5. annotations:
  6. openebs.io/cas-type: jiva
  7. cas.openebs.io/config: |
  8. - name: StoragePool
  9. value: default
  10. provisioner: openebs.io/provisioner-iscsi

5.2.3 hostpath

  1. apiVersion: storage.k8s.io/v1
  2. kind: StorageClass
  3. metadata:
  4. name: localpv-hostpath-sc
  5. annotations:
  6. openebs.io/cas-type: local
  7. cas.openebs.io/config: |
  8. - name: BasePath
  9. value: "/var/openebs/local"
  10. - name: StorageType
  11. value: "hostpath"
  12. provisioner: openebs.io/local

5.2.4 device

下面的类型需要添加硬盘

  1. 磁盘 /dev/sdc:21.5 GB, 21474836480 字节,41943040 个扇区
  2. Units = 扇区 of 1 * 512 = 512 bytes
  3. 扇区大小(逻辑/物理):512 字节 / 512 字节
  4. I/O 大小(最小/最佳):512 字节 / 512 字节
  5. 磁盘标签类型:gpt
  6. Disk identifier: BAD0A706-0A9D-478A-85C6-319224EC5D1F
  7. # Start End Size Type Name
  8. 1 2048 41943006 20G Linux filesyste OpenEBS_NDM
  1. apiVersion: storage.k8s.io/v1
  2. kind: StorageClass
  3. metadata:
  4. name: localpv-device-sc
  5. annotations:
  6. openebs.io/cas-type: local
  7. cas.openebs.io/config: |
  8. - name: StorageType
  9. value: "device"
  10. - name: FSType
  11. value: ext4
  12. provisioner: openebs.io/local

查看:

  1. [root@k8s-master01 openebs]# kubectl get sc -n openebs
  2. NAME PROVISIONER RECLAIMPOLICY VOLUMEBINDINGMODE ALLOWVOLUMEEXPANSION AGE
  3. cstor-csi-disk cstor.csi.openebs.io Delete Immediate true 43s
  4. openebs-device openebs.io/local Delete WaitForFirstConsumer false 9h
  5. openebs-hostpath openebs.io/local Delete WaitForFirstConsumer false 9h

5.2.5 cStor、Jiva、LocalPV 特性比较:

特性JivacStorLocal PV
轻量级运行于用户空间YesYesYes
同步复制YesYesNo
适合低容量工作负载YesYesYes
支持快照,克隆BasicAdvancedNo
数据一致性YesYesNA
使用 Velero 恢复备份YesYesYes
适合高容量工作负载NoYesYes
自动精简配置YesNo
磁盘池或聚合支持YesNo
动态扩容YesYes
数据弹性 (RAID 支持)YesNo
接近原生磁盘性能NoNoYes

大多数场景推荐 cStor,因其提供了强大的功能,包括快照 / 克隆、存储池功能(如精简资源调配、按需扩容等)。

Jiva 适用于低容量需求的工作负载场景,例如 550G。尽管使用 Jiva 没有空间限制,但建议将其用于低容量工作负载。Jiva 非常易于使用,并提供企业级容器本地存储,而不需要专用硬盘。有快照和克隆功能的需求的场景,优先考虑使用 cStor 而不是 Jiva

5.3 默认sc

kubectl patch storageclass cstor-csi-disk -p '{"metadata": {"annotations":{"storageclass.kubernetes.io/is-default-class":"true"}}}'
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/秋刀鱼在做梦/article/detail/891106
推荐阅读
相关标签
  

闽ICP备14008679号