0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

評(píng)估K8s可用的最常見的存儲(chǔ)解決方案

存儲(chǔ)加速器 ? 來源:存儲(chǔ)社區(qū) ? 作者:存儲(chǔ)社區(qū) ? 2021-01-03 10:37 ? 次閱讀

如果你正在運(yùn)行K8s,其中最大的難題之一是如何為k8s集群選擇正確的存儲(chǔ)技術(shù),你可能會(huì)考慮使用通過動(dòng)態(tài)預(yù)配置的塊存儲(chǔ)。實(shí)際上,這很大程度上取決于您要運(yùn)行的工作負(fù)載的類型。本篇文章的目標(biāo)主要是評(píng)估K8s可用的最常見的存儲(chǔ)解決方案,并進(jìn)行基本性能測試。

目前CNCF的存儲(chǔ)格局和解決方案已經(jīng)更新,它已從2019年的30個(gè)解決方案增長到目前的45個(gè)解決方案,還進(jìn)行了公共云集成的管理擴(kuò)展,例如AWS EBS,Google永久磁盤或Azure磁盤存儲(chǔ)。一些新解決方案像Alluxio一樣,更側(cè)重于分布式文件系統(tǒng)或?qū)ο蟠鎯?chǔ)。

本文的目標(biāo)是采用K8s可用的最常見的存儲(chǔ)解決方案,并準(zhǔn)備基本的性能比較。文章使用以下后端在Azure AKS上執(zhí)行所有測試:

  • AKS native storage class — Azure native premium

  • AWS cloud volume mapped into instance — Azure hostPath with attached Azure managed disk

  • OpenEBS with cStor backend

  • OpenEBS MayaStor

  • Portworx

  • Gluster managed by Heketi

  • Ceph managed by Rook

  • Longhorn

相比于19年的存儲(chǔ)方案,GlusterFS Heketi在性能結(jié)果上排名倒數(shù)第二,它的改進(jìn)為零,并且大多數(shù)情況下是一個(gè)沉寂的項(xiàng)目(Heketi作為REST協(xié)調(diào)器而不是GlusterFS本身)。如果查看它們的官方GitHub,您會(huì)發(fā)現(xiàn)他們近乎將其置于維護(hù)模式,并且云本地存儲(chǔ)功能沒有任何更新。

另外根據(jù)GIGAOM 2020報(bào)告, PortWorx仍然是K8s的頂級(jí)商業(yè)存儲(chǔ)解決方案。但是,從性能的角度來看,版本2.0和2.5之間的發(fā)行說明中并沒有重大的技術(shù)或體系結(jié)構(gòu)更改。最好的開源存儲(chǔ),是通過Rook精心策劃的CEPH,他發(fā)布了2個(gè)新版本,并推出了一個(gè)新的CEPH版本,稱為Octopus。Octopus對(duì)緩存機(jī)制進(jìn)行了一些優(yōu)化,并使用了更現(xiàn)代的內(nèi)核接口。今年唯一的主要體系結(jié)構(gòu)更改發(fā)生在OpenEBS中,它引入了一個(gè)稱為MayaStor的新后端。這個(gè)后端看起來非常有前途。這些k8s常用的解決方案性能到底怎么樣了?我們一起來看下。

本機(jī)Azure存儲(chǔ)

之所以選擇該存儲(chǔ)類,是為了獲得所有測試的基準(zhǔn)。此存儲(chǔ)類應(yīng)提供最佳性能。Azure動(dòng)態(tài)創(chuàng)建托管磁盤,并將其映射到具有k8s作為Pod卷的VM。

81534c9c-4655-11eb-8b86-12bb97331649.png

無需使用任何特殊功能。當(dāng)您配置新的AKS群集時(shí),將自動(dòng)預(yù)定義2個(gè)存儲(chǔ)類,分別稱為“默認(rèn)”和“高級(jí)托管”。高級(jí)類對(duì)卷使用基于SSD的高性能和低延遲磁盤。

優(yōu)點(diǎn)

  • AKS上的默認(rèn)設(shè)置無需執(zhí)行任何操作。

缺點(diǎn)

  • 故障轉(zhuǎn)移情況下非常慢,有時(shí)需要將近10分鐘才能將卷重新連接到其他節(jié)點(diǎn)上的Pod。

$ kubectl get storageclassesNAME                PROVISIONER                AGEdefault (default)   kubernetes.io/azure-disk   8mmanaged-premium     kubernetes.io/azure-disk   8m
$ kubectl get pvcNAME              STATUS    VOLUME                                     CAPACITY   ACCESS MODES   STORAGECLASS      AGEdbench-pv-claim   Bound     pvc-e7bd34a4-1dbd-11e9-8726-ae508476e8ad   1000Gi     RWO            managed-premium   10s
$ kubectl get poNAME           READY     STATUS              RESTARTS   AGEdbench-w7nqf0/1ContainerCreating029s

OpenEBS

OpenEBS代表了新的容器附加存儲(chǔ)(CAS)概念,其中是單個(gè)基于微服務(wù)的存儲(chǔ)控制器和多個(gè)基于微服務(wù)的存儲(chǔ)副本。它與Portworx一起屬于云本機(jī)存儲(chǔ)類別。

81d4be9e-4655-11eb-8b86-12bb97331649.png

它是完全開源的,目前提供2個(gè)后端,分別是Jiva和cStor。我從Jiva開始,然后切換到cStor。cStor進(jìn)行了一些改進(jìn),因?yàn)榭刂破骷捌涓北静渴鹪趩蝹€(gè)名稱空間(安裝openebs的名稱空間)中,或者它使用原始磁盤而不是格式化分區(qū)。每個(gè)k8s卷都有其自己的存儲(chǔ)控制器,該存儲(chǔ)可以在節(jié)點(diǎn)上可用存儲(chǔ)容量的允許范圍內(nèi)進(jìn)行擴(kuò)展。

如何在AKS上獲取它?在AKS上安裝其實(shí)非常容易。

1.我必須連接到所有k8s節(jié)點(diǎn)的控制臺(tái)并安裝iSCSI,因?yàn)樗褂胕SCSI協(xié)議在Pod和存儲(chǔ)控制器與k8s節(jié)點(diǎn)之間進(jìn)行連接。

apt-get updateapt install -y open-iscsi

2.然后,我將單個(gè)YAML定義應(yīng)用于我的k8s集群

kubectl apply -f https://openebs.github.io/charts/openebs-operator-0.8.0.yaml

3.下一步,OpenEBS控制器在底層節(jié)點(diǎn)發(fā)現(xiàn)了我所有的磁盤。但是我必須手動(dòng)確定附加的AWS托管磁盤。

kubectl get diskNAME                                      AGEdisk-184d99015253054c48c4aa3f17d137b1     5mdisk-2f6bced7ba9b2be230ca5138fd0b07f1     5mdisk-806d3e77dd2e38f188fdaf9c46020bdc     5m

4.然后,將這些磁盤添加到標(biāo)準(zhǔn)StorageClass引用的自定義k8s資源StoragePoolClaim中。

---apiVersion: storage.k8s.io/v1kind: StorageClassmetadata:  name: openebs-custom  annotations:    openebs.io/cas-type: cstor    cas.openebs.io/config: |      - name: StoragePoolClaim        value: "cstor-disk"provisioner: openebs.io/provisioner-iscsi---apiVersion: openebs.io/v1alpha1kind: StoragePoolClaimmetadata:  name: cstor-diskspec:  name: cstor-disk  type: disk  maxPools: 3  poolSpec:    poolType: striped  disks:    diskList:    - disk-2f6bced7ba9b2be230ca5138fd0b07f1    - disk-806d3e77dd2e38f188fdaf9c46020bdc    - disk-184d99015253054c48c4aa3f17d137b1

完成這些步驟后,我便能夠通過k8s PVC動(dòng)態(tài)配置新卷。

優(yōu)點(diǎn)

  • 開源的

  • Maya在資源使用可視化方面做得很好。您可以輕松地在k8s集群中部署多個(gè)服務(wù),并輕松設(shè)置監(jiān)視和日志記錄以收集集群的所有重要方面。這是調(diào)試的理想工具。

  • 總的來說,CAS概念–我非常喜歡容器存儲(chǔ)背后的想法,并且我相信會(huì)有未來。

  • OpenEBS背后的社區(qū)—我能夠在幾分鐘內(nèi)解決任何問題。Slack上的團(tuán)隊(duì)非常有幫助。

缺點(diǎn)

  • 不成熟-OpenEBS是一個(gè)相當(dāng)新的項(xiàng)目,尚未達(dá)到穩(wěn)定版本。核心團(tuán)隊(duì)仍在進(jìn)行后端優(yōu)化,這將在接下來的幾個(gè)月中顯著提高性能。

  • Kubelet和存儲(chǔ)控制器之間的iSCSI連接由k8s服務(wù)實(shí)現(xiàn),這在某些覆蓋網(wǎng)絡(luò)CNI插件(例如Tungsten Fabric)中可能是一個(gè)問題。

  • 需要在Kubernetes節(jié)點(diǎn)上安裝其他軟件(iSCSI),這使其在托管Kubernetes集群的情況下不切實(shí)際。

注意:OpenEBS團(tuán)隊(duì)在文檔中調(diào)整了相關(guān)的測試用例場景

https://github.com/kmova/openebs/tree/fio-perf-tests/k8s/demo/dbench

Portworx

Portworx是為k8s設(shè)計(jì)的另一種容器本機(jī)存儲(chǔ),專注于高度分布式的環(huán)境。它是一個(gè)主機(jī)可尋址的存儲(chǔ),其中每個(gè)卷都直接映射到其連接的主機(jī)。它提供基于應(yīng)用程序I/O類型的自動(dòng)調(diào)整。那里有更多信息。不幸的是,它是本篇文章中唯一的不開源的存儲(chǔ)解決方案。但是,它免費(fèi)提供3個(gè)節(jié)點(diǎn)試用版。

82288704-4655-11eb-8b86-12bb97331649.png

如何在AKS上安裝它?在AKS上安裝也非常容易。我使用了可在其網(wǎng)站上找到的Kubernetes spec生成器。

1.首選,我選擇了Portworx托管的etcd來簡化設(shè)置,并填充了k8s 1.11.4版本。

2.我必須將數(shù)據(jù)網(wǎng)絡(luò)接口修改為azure0,因?yàn)槲沂褂玫氖蔷哂懈呒?jí)聯(lián)網(wǎng)功能的Azure cni。否則,Portworx將使用來自docker bridge的IP地址而不是VM接口。

3.最后一步,網(wǎng)站生成器向我提供了渲染的k8s YAML清單以應(yīng)用于我的集群。

4.引導(dǎo)后,我在每個(gè)k8s節(jié)點(diǎn)上運(yùn)行了Portworx Pod

root@aks-agentpool-20273348-0:~# kubectl get pods -o wide -n kube-system -l name=portworxNAME             READY     STATUS    RESTARTS   AGE       IP          NODE                       NOMINATED NODEportworx-g9csq   1/1       Running   0          14m       10.0.1.66   aks-agentpool-20273348-2   <none>portworx-nt2lq   1/1       Running   0          14m       10.0.1.4    aks-agentpool-20273348-0   <none>portworx-wcjnx   1/1       Running   0          14m       10.0.1.35   aks-agentpool-20273348-1   <none>

我創(chuàng)建了具有高優(yōu)先級(jí)和3個(gè)副本的Storage Class,然后可以配置k8s pvc。

優(yōu)點(diǎn)

  • 易于部署-具有詳細(xì)配置的網(wǎng)站配置器。

  • AKS集群的配置器,不需要任何其他步驟,如ceph或glusterfs。

  • 云原生存儲(chǔ),它可以在硬件集群和公共云上運(yùn)行。

  • 存儲(chǔ)感知的服務(wù)等級(jí)(COS)和應(yīng)用感知的I/O調(diào)整

缺點(diǎn)

  • 閉源,專有供應(yīng)商解決方案。

GlusterFS Heketi

GlusterFS是眾所周知的開源存儲(chǔ)解決方案。它沿用Ceph,這是RedHat支持的傳統(tǒng)開源存儲(chǔ)之一。Heketi是用于GlusterFS的RESTful卷管理接口。它提供了一種釋放動(dòng)態(tài)配置的GlusterFS卷功能的便捷方法。如果沒有此訪問權(quán)限,則必須手動(dòng)創(chuàng)建GlusterFS卷并將其映射到k8s pv。

8296ef46-4655-11eb-8b86-12bb97331649.png

如何在AKS上安裝它?我使用了默認(rèn)的Heketi快速入門指南。

  1. 首先,我基于示例一創(chuàng)建了一個(gè)拓?fù)湮募?,其中包含磁盤和主機(jī)名。

https://github.com/gluster/gluster-kubernetes/blob/master/deploy/topology.json.sample

2.由于Heketi主要是在基于RHEL的操作系統(tǒng)上開發(fā)和測試的,因此我在使用Ubuntu主機(jī)的AKS上遇到了一個(gè)問題,該內(nèi)核路徑錯(cuò)誤。這是解決此問題的PR。

https://github.com/gluster/gluster-kubernetes/pull/557
+++ b/deploy/kube-templates/glusterfs-daemonset.yaml@@ -67,7 +67,7 @@ spec:           mountPath: "/etc/ssl"           readOnly: true         - name: kernel-modules-          mountPath: "/usr/lib/modules"+          mountPath: "/lib/modules"           readOnly: true         securityContext:           capabilities: {}@@ -131,4 +131,4 @@ spec:           path: "/etc/ssl"       - name: kernel-modules         hostPath:-          path: "/usr/lib/modules"+          path: "/lib/modules"

3.我遇到的AKS的另一個(gè)問題是非空磁盤,因此我使用了擦拭來清理glusterfs的磁盤。該磁盤以前沒有用于其他任何用途。

wipefs -a /dev/sdc/dev/sdc: 8 bytes were erased at offset 0x00000218 (LVM2_member): 4c 56 4d 32 20 30 30 31

4.最后一步,我運(yùn)行命令gk-deploy -g -t topology.json,該命令在由heketi控制器控制的每個(gè)節(jié)點(diǎn)上部署了glusterfs pod。

root@aks-agentpool-20273348-0:~# kubectl get po -o wideNAME                     READY   STATUS    RESTARTS IP        NODE                       NOMINATED NODEglusterfs-fgc8f          1/1     Running   0       10.0.1.35  aks-agentpool-20273348-1glusterfs-g8ht6          1/1     Running   0       10.0.1.4   aks-agentpool-20273348-0glusterfs-wpzzp          1/1     Running   0       10.0.1.66  aks-agentpool-20273348-2heketi-86f98754c-n8qfb   1/1     Running   0       10.0.1.69  aks-agentpool-20273348-2

然后,我面臨著動(dòng)態(tài)配置的問題。Heketi restURL對(duì)k8s控制平面不可用。我嘗試了kube dns記錄,pod IP和svc IP。兩者都不起作用。因此,我不得不通過Heketi CLI手動(dòng)創(chuàng)建卷。

root@aks-agentpool-20273348-0:~# export HEKETI_CLI_SERVER=http://10.0.1.69:8080root@aks-agentpool-20273348-0:~# heketi-cli volume create --size=10 --persistent-volume --persistent-volume-endpoint=heketi-storage-endpoints | kubectl create -f -persistentvolume/glusterfs-efb3b155 created
root@aks-agentpool-20273348-0:~# kubectl get pvNAME                 CAPACITY   ACCESS MODES   RECLAIM POLICY   STATUS      CLAIM     STORAGECLASS   REASON    AGEglusterfs-efb3b155   10Gi       RWX            Retain           Available                                      19s

然后,必須為我的dbench工具將現(xiàn)有的PV映射到PVC。

kind: PersistentVolumeClaimapiVersion: v1metadata:  name: glusterfs-efb3b155spec:  accessModes:    - ReadWriteMany  storageClassName: ""  resources:    requests:      storage: 10Gi  volumeName: glusterfs-efb3b155
kubectl get pvcNAME                 STATUS    VOLUME               CAPACITY   ACCESS MODES   STORAGECLASS   AGEglusterfs-efb3b155   Bound     glusterfs-efb3b155   10Gi       RWX                           36m

從k8s上的Heketi Gluster安裝獲得更多輸出。

gluster volume info vol_efb3b15529aa9aba889d7900f0ce9849
Volume Name: vol_efb3b15529aa9aba889d7900f0ce9849Type: ReplicateVolume ID: 96fde36b-e389-4dbe-887b-baae32789436Status: StartedSnapshot Count: 0Number of Bricks: 1 x 3 = 3Transport-type: tcpBricks:Brick1: 10.0.1.66:/var/lib/heketi/mounts/vg_5413895eade683e1ca035760c1e0ffd0/brick_cd7c419bc4f4ff38bbc100c6d7b93605/brickBrick2: 10.0.1.35:/var/lib/heketi/mounts/vg_3277c6764dbce56b5a01426088901f6d/brick_6cbd74e9bed4758110c67cfe4d4edb53/brickBrick3: 10.0.1.4:/var/lib/heketi/mounts/vg_29d6152eeafc57a707bef56f091afe44/brick_4856d63b721d794e7a4cbb4a6f048d96/brickOptions Reconfigured:transport.address-family: inetnfs.disable: onperformance.client-io-threads: off
kubectl get svcNAME                       TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)    AGEheketi                     ClusterIP   192.168.101.75           8080/TCP   5hheketi-storage-endpoints   ClusterIP   192.168.103.66           1/TCP      5h
root@aks-agentpool-20273348-0:~# kubectl get endpointsNAME                       ENDPOINTS                            AGEheketi                     10.0.1.69:8080                       5hheketi-storage-endpoints   10.0.1.35:1,10.0.1.4:1,10.0.1.66:1   5hkubernetes                 172.31.22.152:443                    1droot@aks-agentpool-20273348-0:~# kubectl get endpoints heketi-storage-endpoints -o yamlapiVersion: v1kind: Endpointsmetadata:  creationTimestamp: 2019-01-29T15:14:28Z  name: heketi-storage-endpoints  namespace: default  resourceVersion: "142212"  selfLink: /api/v1/namespaces/default/endpoints/heketi-storage-endpoints  uid: 91f802eb-23d8-11e9-bfcb-a23b1ec87092subsets:- addresses:  - ip: 10.0.1.35  - ip: 10.0.1.4  - ip: 10.0.1.66  ports:  - port: 1    protocol: TCP

優(yōu)點(diǎn)

  • 成熟的存儲(chǔ)解決方案

  • 比Ceph更輕

缺點(diǎn)

  • Heketi不是為公共管理的k8設(shè)計(jì)的。它與HW群集配合使用,安裝更容易。

  • 并非真正為“結(jié)構(gòu)化數(shù)據(jù)”設(shè)計(jì)的,如SQL數(shù)據(jù)庫。但是,您可以使用Gluster備份和還原數(shù)據(jù)庫。

Ceph Rook

OpenStack私有云常見和Ceph進(jìn)行搭配。它始終需要設(shè)計(jì)特定的硬件配置,根據(jù)數(shù)據(jù)類型生成pg組,配置日志SSD分區(qū)(在bluestore之前)并定義Crush Map。因此,當(dāng)我第一次聽說在3節(jié)點(diǎn)k8s集群中使用Ceph時(shí),我不敢相信它實(shí)際上可以工作。但是,Rook編排工具給我留下了深刻的印象,該工具為我完成了所有痛苦的步驟,并且與k8s編排一起提供了一種非常簡單的方法來處理整個(gè)存儲(chǔ)集群的安裝。

82f1800a-4655-11eb-8b86-12bb97331649.png

如何在AKS上安裝它?在默認(rèn)安裝中,Rook不需要任何特殊步驟,并且如果您不希望使用高級(jí)配置,它會(huì)非常平滑。

1.我使用了Ceph快速入門指南

https://github.com/rook/rook/blob/master/Documentation/ceph-quickstart.md#ceph-storage-quickstart

2.我必須配置特定于AKS的FLEXVOLUME_DIR_PATH,因?yàn)樗鼈兪褂?etc/kubernetes/volumeplugins/ 而不是默認(rèn)的Ubuntu /usr/libexec。沒有此更改,kubelet無法安裝pvc 。

diff --git a/cluster/examples/kubernetes/ceph/operator.yaml b/cluster/examples/kubernetes/ceph/operator.yamlindex 73cde2e..33f45c8 100755--- a/cluster/examples/kubernetes/ceph/operator.yaml+++ b/cluster/examples/kubernetes/ceph/operator.yaml@@ -431,8 +431,8 @@ spec:         # - name: AGENT_MOUNT_SECURITY_MODE         #   value: "Any"         # Set the path where the Rook agent can find the flex volumes-        # - name: FLEXVOLUME_DIR_PATH-        #  value: ""+        - name: FLEXVOLUME_DIR_PATH+          value: "/etc/kubernetes/volumeplugins"         # Set the path where kernel modules can be found         # - name: LIB_MODULES_DIR_PATH         #  value: ""

3.然后,我必須指定要在deviceFilter中使用的設(shè)備。我的附加磁盤始終位于/dev/sdc上

diff --git a/cluster/examples/kubernetes/ceph/cluster.yaml b/cluster/examples/kubernetes/ceph/cluster.yamlindex 48cfeeb..0c91c48 100755--- a/cluster/examples/kubernetes/ceph/cluster.yaml+++ b/cluster/examples/kubernetes/ceph/cluster.yaml@@ -227,7 +227,7 @@ spec:   storage: # cluster level storage configuration and selection     useAllNodes: true     useAllDevices: false-    deviceFilter:+    deviceFilter: "^sdc"     location:     config:

4.安裝后,我使用以下配置創(chuàng)建了Ceph塊池和存儲(chǔ)類

apiVersion: ceph.rook.io/v1kind: CephBlockPoolmetadata:  name: replicapool  namespace: rook-cephspec:  failureDomain: host  replicated:    size: 3---apiVersion: storage.k8s.io/v1kind: StorageClassmetadata:   name: rook-ceph-blockprovisioner: ceph.rook.io/blockparameters:  blockPool: replicapool  clusterNamespace: rook-ceph  fstype: xfsreclaimPolicy: Retain

5。最后,我通過以下部署工具檢查狀態(tài):https://github.com/rook/rook/blob/master/Documentation/ceph-toolbox.md

ceph status  cluster:    id:     bee70a10-dce1-4725-9285-b9ec5d0c3a5e    health: HEALTH_OK
  services:    mon: 3 daemons, quorum c,b,a    mgr: a(active)    osd: 3 osds: 3 up, 3 in
  data:    pools:   0 pools, 0 pgs    objects: 0  objects, 0 B    usage:   3.0 GiB used, 3.0 TiB / 3.0 TiB avail    pgs:
[root@aks-agentpool-27654233-0 /]#[root@aks-agentpool-27654233-0 /]#[root@aks-agentpool-27654233-0 /]# ceph osd status+----+--------------------------+-------+-------+--------+---------+--------+---------+-----------+| id |           host           |  used | avail | wr ops | wr data | rd ops | rd data |   state   |+----+--------------------------+-------+-------+--------+---------+--------+---------+-----------+| 0  | aks-agentpool-27654233-0 | 1025M | 1021G |    0   |     0   |    0   |     0   | exists,up || 1  | aks-agentpool-27654233-1 | 1025M | 1021G |    0   |     0   |    0   |     0   | exists,up || 2  | aks-agentpool-27654233-2 | 1025M | 1021G |    0   |     0   |    0   |     0   | exists,up |+----+--------------------------+-------+-------+--------+---------+--------+---------+-----------+

優(yōu)點(diǎn)

  • 在大型生產(chǎn)環(huán)境中運(yùn)行的強(qiáng)大存儲(chǔ)

  • Rook使生命周期管理變得更加簡單。

缺點(diǎn)

  • 復(fù)雜且更重,甚至不適合在公共云中運(yùn)行。最好只在配置正確的硬件群集上運(yùn)行。

    Longhorn

Longhorn是Rancher開發(fā)的用于K8s的云原生分布式塊存儲(chǔ)。它主要是為微服務(wù)用例設(shè)計(jì)的。它為每個(gè)塊設(shè)備卷創(chuàng)建一個(gè)專用的存儲(chǔ)控制器,并跨存儲(chǔ)在多個(gè)節(jié)點(diǎn)上的多個(gè)副本同步復(fù)制該卷。Longhorn在附加了卷的節(jié)點(diǎn)上創(chuàng)建了Longhorn Engine,并在復(fù)制了卷的節(jié)點(diǎn)上創(chuàng)建了副本。與其他存儲(chǔ)方案類似,整個(gè)控制平面正常運(yùn)行,而數(shù)據(jù)平面由K8s編排。它是完全開源的。有趣的是,OpenEBS Jiva后端實(shí)際上是基于Longhorn的,或者至少最初是基于Longhorn的。主要區(qū)別在于Longhorn使用TCMU Linux驅(qū)動(dòng)程序,而OpenEBS Jiva使用的是gotgt。

8355ae9a-4655-11eb-8b86-12bb97331649.jpg

如何在AKS上獲取它?當(dāng)然也可以輕松安裝到AKS,只需要運(yùn)行一個(gè)命令,它將所有組件安裝到我的AKS集群中

$ kubectl apply -f https://raw.githubusercontent.com/longhorn/longhorn/master/deploy/longhorn.yaml
$ kubectl -n longhorn-system get poNAME                                        READY   STATUS    RESTARTS   AGEcsi-attacher-7965bb8b59-c4g2c               1/1     Running   0          116scsi-attacher-7965bb8b59-jqk9t               1/1     Running   0          116scsi-attacher-7965bb8b59-qrxl6               1/1     Running   0          116scsi-provisioner-5896666d9b-9lss2            1/1     Running   0          115scsi-provisioner-5896666d9b-v7wwd            1/1     Running   0          115scsi-provisioner-5896666d9b-vsq6v            1/1     Running   0          115scsi-resizer-98674fffd-27wgb                 1/1     Running   0          115scsi-resizer-98674fffd-q6scx                 1/1     Running   0          115scsi-resizer-98674fffd-rr7qc                 1/1     Running   0          115sengine-image-ei-ee18f965-5npvk              1/1     Running   0          2m44sengine-image-ei-ee18f965-9lp7w              1/1     Running   0          2m44sengine-image-ei-ee18f965-h7b4x              1/1     Running   0          2m44sinstance-manager-e-27146777                 1/1     Running   0          2m42sinstance-manager-e-58362831                 1/1     Running   0          2m40sinstance-manager-e-6043871c                 1/1     Running   0          2m43sinstance-manager-r-5cdb90bf                 1/1     Running   0          2m40sinstance-manager-r-cb47162a                 1/1     Running   0          2m41sinstance-manager-r-edd5778b                 1/1     Running   0          2m42slonghorn-csi-plugin-7xzw9                   2/2     Running   0          115slonghorn-csi-plugin-m8cp4                   2/2     Running   0          115slonghorn-csi-plugin-wzgp8                   2/2     Running   0          115slonghorn-driver-deployer-699db744fd-8j6q6   1/1     Running   0          3m8slonghorn-manager-c5647                      1/1     Running   1          3m10slonghorn-manager-dlsmc                      1/1     Running   0          3m10slonghorn-manager-jrnfx                      1/1     Running   1          3m10slonghorn-ui-64bd57fb9d-qjmsl                1/1     Running   0          3m9s

2.將帶有ext4文件系統(tǒng)的/dev/sdc1掛載到/var/lib/longhorn,這是卷存儲(chǔ)的默認(rèn)路徑。最好在Longhorn安裝之前將磁盤安裝到那里。

83b2503c-4655-11eb-8b86-12bb97331649.png

Longhorn中節(jié)點(diǎn)磁盤配置的屏幕截圖

3.最后一步是創(chuàng)建一個(gè)具有3個(gè)副本定義的默認(rèn)存儲(chǔ)類。

# kubectl create -f https://raw.githubusercontent.com/longhorn/longhorn/master/examples/storageclass.yaml
kind: StorageClassapiVersion: storage.k8s.io/v1metadata:  name: longhornprovisioner: driver.longhorn.ioallowVolumeExpansion: trueparameters:  numberOfReplicas: "3"  staleReplicaTimeout: "2880" # 48 hours in minutes  fromBackup: ""

優(yōu)點(diǎn)

  • 開源的

  • 云原生存儲(chǔ),它可以在硬件集群和公共云上運(yùn)行。

  • 易于部署,它只需要一個(gè)命令,并且“開箱即用”。

  • 自動(dòng)卷備份/還原到S3

缺點(diǎn)

  • 它使用標(biāo)準(zhǔn)文件系統(tǒng)(ext4或xfs)到/var/lib/longhorn的掛載點(diǎn)。每個(gè)卷就像一個(gè)磁盤文件。它可以隨著許多控制器副本進(jìn)行擴(kuò)展,從而帶來額外的網(wǎng)絡(luò)開銷。類似于我為OpenEBS Jiva描述的內(nèi)容。

  • 卷的掛載有時(shí)會(huì)花費(fèi)很長時(shí)間(幾分鐘),并且會(huì)顯示最終從中恢復(fù)的錯(cuò)誤。

OpenEBS MayaStor

上文有介紹OpenEBS使用cStor的方案,其性能結(jié)果確實(shí)很差。但是一年半后的時(shí)間,OpenEBS團(tuán)隊(duì)引入了一個(gè)名為MayStor的新后端。

這是用Rust編寫的云原生聲明性數(shù)據(jù)平面,由2個(gè)組件組成:

  • 以CSI概念和數(shù)據(jù)平面實(shí)現(xiàn)的控制平面。與以前的后端相比,主要區(qū)別在于利用NVMe而不是NVMe-oF,這有望為存儲(chǔ)敏感型工作負(fù)載提供更好的IOPS和延遲價(jià)值。

  • 這種存儲(chǔ)設(shè)計(jì)的另一個(gè)優(yōu)點(diǎn)是,它在主機(jī)用戶空間中完全用盡了內(nèi)核,并消除了由不同Linux發(fā)行版中可用的各種內(nèi)核引起的差異。它根本不依賴于內(nèi)核進(jìn)行訪問。下面的鏈接中,詳細(xì)介紹了MayStor的設(shè)計(jì)說明。

https://blog.mayadata.io/openebs/mayastor-crossing-the-chasm-to-nvmf-infinity-and-beyond

如何在AKS上獲取它?在AKS上進(jìn)行安裝也非常簡單,我遵循了他們的快速入門指南。

  1. 我必須在AKS群集中的每個(gè)節(jié)點(diǎn)上用512個(gè)數(shù)字配置2MB的大頁面。

echo 512 | sudo tee /sys/kernel/mm/hugepages/hugepages-2048kB/nr_hugepages

但是我決定通過下面的k8s daemonset強(qiáng)制執(zhí)行它們,而不是通過ssh進(jìn)入我的每個(gè)實(shí)例。

apiVersion: apps/v1kind: DaemonSetmetadata:  name: hugepages-ensure  namespace: mayastor  labels:    app: hugepages-ensurespec:  selector:    matchLabels:      name: hugepages-ensure  updateStrategy:    type: OnDelete  template:    metadata:      name: hugepages-ensure      labels:        name: hugepages-ensure        app: hugepages-ensure    spec:      containers:      - name: shell        image: busybox:latest        imagePullPolicy: IfNotPresent        command:          - /bin/sh        args:          - -c          - "while true; do echo 512 | tee /sys/kernel/mm/hugepages/hugepages-2048kB/nr_hugepages;grep HugePages /proc/meminfo; sleep 6000; done"        volumeMounts:          - mountPath: /host-root            name: host-root        securityContext:          privileged: true      dnsPolicy: ClusterFirstWithHostNet      hostNetwork: true      volumes:        - name: host-root          hostPath:            path: /

2.我必須標(biāo)記我的存儲(chǔ)節(jié)點(diǎn)VM。

kubectl label node aks-agentpool-13651304-0 openebs.io/engine=mayastornode/aks-agentpool-13651304-0 labeledkubectl label node aks-agentpool-13651304-1 openebs.io/engine=mayastornode/aks-agentpool-13651304-1 labeledkubectl label node aks-agentpool-13651304-2 openebs.io/engine=mayastornode/aks-agentpool-13651304-2 labeled

3.然后,我應(yīng)用了MayaStor存儲(chǔ)庫中指定的所有清單。

https://github.com/openebs/Mayastor/tree/develop/deploy
kubectl create -f nats-deployment.yamlkubectl create -f csi-daemonset.yamlkubectl create -f mayastorpoolcrd.yamlkubectl create -f moac-rbac.yamlkubectl create -f moac-deployment.yamlkubectl create -f mayastor-daemonset.yaml
kubectl get po -n mayastorNAME                     READY   STATUS    RESTARTS   AGEhugepages-ensure-5dr26   1/1     Running   0          47hhugepages-ensure-tpth6   1/1     Running   0          47hhugepages-ensure-z9mmh   1/1     Running   0          47hmayastor-csi-7rf2l       2/2     Running   0          47hmayastor-csi-hbqlb       2/2     Running   0          47hmayastor-csi-jdw7k       2/2     Running   0          47hmayastor-g9gnl           1/1     Running   7          47hmayastor-j7j4q           1/1     Running   4          47hmayastor-kws9r           1/1     Running   4          47hmoac-7d487fd5b5-hfvhq    3/3     Running   0          41hnats-b4cbb6c96-8drv4     1/1     Running   0          47h

4.當(dāng)所有內(nèi)容都在運(yùn)行時(shí),您可以開始創(chuàng)建用于卷置備的存儲(chǔ)池。在我的情況下,我創(chuàng)建了3個(gè)存儲(chǔ)池,每個(gè)節(jié)點(diǎn)有一個(gè)磁盤。

cat <apiVersion: openebs.io/v1alpha1kind: MayastorPoolmetadata:  name: pool-on-node-1  namespace: mayastorspec:  disks:  - /dev/sdc  node: aks-agentpool-13651304-1EOF
kubectl -n mayastor get MayastorPoolNAME             NODE                       STATE    AGEpool-on-node-0   aks-agentpool-13651304-0   online   40hpool-on-node-1   aks-agentpool-13651304-1   online   46hpool-on-node-2   aks-agentpool-13651304-2   online   46h

5.在繼續(xù)進(jìn)行StorageClass定義之前,檢查每個(gè)存儲(chǔ)池的狀態(tài)很重要。狀態(tài)必須可見。

kubectl -n mayastor describe msp pool-on-node-1Name:         pool-on-node-1Namespace:    mayastorLabels:       API Version:  openebs.io/v1alpha1Kind:         MayastorPoolMetadata:  Creation Timestamp:  2020-08-19T0852Z  Generation:          1  Resource Version:    45513  Self Link:           /apis/openebs.io/v1alpha1/namespaces/mayastor/mayastorpools/pool-on-node-1  UID:                 5330a0be-bebe-445a-9285-856511e318dcSpec:  Disks:    /dev/sdc  Node:  aks-agentpool-13651304-1Status:  Capacity:  1098433691648  Disks:    aio:///dev/sdc  Reason:  State:   online  Used:    1073741824Events:    

6.該過程的最后一步是StorageClass定義,在其中,我配置了3個(gè)副本以具有與之前的存儲(chǔ)解決方案相同的測試環(huán)境。

cat <kind: StorageClassapiVersion: storage.k8s.io/v1metadata:  name: mayastorparameters:  repl: '3'  protocol: 'iscsi'provisioner: io.openebs.csi-mayastorEOF

完成這些步驟后,我便能夠通過K8s PVC動(dòng)態(tài)預(yù)配新卷。

優(yōu)點(diǎn)

  • 具有強(qiáng)大社區(qū)支持的開源

  • 云原生存儲(chǔ),它可以在硬件集群和公共云上運(yùn)行。

  • 與僅具有一個(gè)隊(duì)列的SCSI相比,NVMe的使用旨在實(shí)現(xiàn)高度并行性,并且可以具有64K隊(duì)列。

  • 它使用NVMe-oF作為傳輸方式,可以在各種傳輸方式(nvmf,uring,pcie)上工作,并且完全在用戶空間(目標(biāo)用戶和發(fā)起者)中完成。在用戶空間中運(yùn)行可以避免進(jìn)行大量的系統(tǒng)調(diào)用,避免后期崩潰/崩潰等。而且它與內(nèi)核無關(guān),因此跨云或物理環(huán)境的linux類型之間沒有區(qū)別。

缺點(diǎn)

  • 早期版本-OpenEBS MayaStor的版本為0.3,因此它仍然存在一些限制和穩(wěn)定性問題。但是,它們走在正確的軌道上,并且在幾個(gè)月后,它可能是在K8中存儲(chǔ)的首選。

  • 需要在Kubernetes節(jié)點(diǎn)上支持2MB的大頁面。但是,與1GB的大頁面相比,幾乎在所有物理或虛擬環(huán)境中都可用。

性能測試結(jié)果

重要說明:單個(gè)存儲(chǔ)性能測試的結(jié)果無法單獨(dú)評(píng)估,但必須將測量結(jié)果相互比較。這里多種執(zhí)行比較測試的方法是相對(duì)比較簡單的。

為了進(jìn)行驗(yàn)證,我使用了與Azure AKS 3節(jié)點(diǎn)群集和每個(gè)實(shí)例均附有1TB高級(jí)SSD托管磁盤的完全相同的實(shí)驗(yàn)室。

為了運(yùn)行測試,我決定使用稱為Dbench的負(fù)載測試器。這是Pod的K8s部署清單,在其中運(yùn)行FIO,這是帶有8個(gè)測試用例的Flexible IO Tester。在Docker映像的入口點(diǎn)中指定了測試:

  • 隨機(jī)讀寫帶寬

  • 隨機(jī)讀寫IOPS

  • 讀寫延遲

  • 順序讀/寫

  • 混合讀/寫IOPS

首先,我運(yùn)行了Azure PVC測試以獲得與去年進(jìn)行比較的基準(zhǔn)。結(jié)果幾乎相同,因此我們可以假設(shè)條件保持不變,并且使用相同的存儲(chǔ)版本將獲得相同的數(shù)量??蓮膆ttps://gist.github.com/pupapaik/76c5b7f124dbb69080840f01bf71f924獲得來自2019年所有測試的更新的完整測試輸出以及新的MayStor和Longhorn測試

隨機(jī)讀寫帶寬

隨機(jī)讀取測試表明,GlusterFS,Ceph和Portworx的讀取性能比Azure本地磁盤上的主機(jī)路徑好幾倍。OpenEBS和Longhorn的性能幾乎是本地磁盤的兩倍。原因是讀取緩存。對(duì)于OpenEBS,寫入速度最快,但是Longhorn和GlusterFS的值也幾乎與本地磁盤相同。

83f92c5a-4655-11eb-8b86-12bb97331649.png

843dc644-4655-11eb-8b86-12bb97331649.png

隨機(jī)讀寫IOPS

Portworx和OpenEBS在隨機(jī)IOPS測試中表現(xiàn)出最好的結(jié)果。這次,OpenEBS在寫入方面的IOPS比本地Azure PVC更好,這在技術(shù)上幾乎是不可能的。它很可能與在測試用例運(yùn)行的不同時(shí)間處的Azure存儲(chǔ)負(fù)載有關(guān)。

848acc50-4655-11eb-8b86-12bb97331649.png

84d47328-4655-11eb-8b86-12bb97331649.png

讀寫延遲

延遲讀取獲勝者與上次相同。LongHorn和OpenEBS幾乎是PortWorx的兩倍。這仍然不錯(cuò),因?yàn)楸緳C(jī)Azure pvc比大多數(shù)其他經(jīng)過測試的存儲(chǔ)要慢。但是,在OpenEBS和Longhorn上寫入期間的延遲更好。GlusterFS仍然比其他存儲(chǔ)要好。

85132a32-4655-11eb-8b86-12bb97331649.png

8574de3a-4655-11eb-8b86-12bb97331649.png

順序讀/寫

順序讀/寫測試顯示的結(jié)果與隨機(jī)測試相似,但是Ceph的讀性能比GlusterFS高2倍。寫入結(jié)果幾乎都處于同一水平,OpenEBS和Longhorn達(dá)到了相同的水平。

85c0e802-4655-11eb-8b86-12bb97331649.png

862ab3e0-4655-11eb-8b86-12bb97331649.png

混合讀/寫IOPS

最后一個(gè)測試用例驗(yàn)證了混合讀寫IOPS,在讀寫方面,OpenEBS交付的速度幾乎是PortWorx或Longhorn的兩倍。

897613d2-4655-11eb-8b86-12bb97331649.png

89cd2ec4-4655-11eb-8b86-12bb97331649.png

結(jié)論

該文章驗(yàn)證了一個(gè)開放源代碼項(xiàng)目在一年內(nèi)可以有多大的變化!作為演示,讓我們看一下在完全相同的環(huán)境下,OpenEBS cStor和OpenEBS MayaStor的IOPS的比較。

8a03a8f0-4655-11eb-8b86-12bb97331649.png

OpenEBS cStor和MayaStor之間的混合讀寫IOPS比較

在選擇存儲(chǔ)空間時(shí),請僅將結(jié)果作為標(biāo)準(zhǔn)之一,不要僅根據(jù)文章做出最終判斷。我們可以從上述的測試中得出以下結(jié)論:

  • Portworx和OpenEBS是AKS上最快的容器存儲(chǔ)。

  • 圍繞NVMe的穩(wěn)健設(shè)計(jì),OpenEBS似乎已成為最好的開源容器存儲(chǔ)選項(xiàng)之一。

  • 對(duì)于硬件集群,Ceph是最好的開源后端存儲(chǔ)。對(duì)于公共云而言,操作過于復(fù)雜,最終與默認(rèn)的云存儲(chǔ)類相比并沒有增加太多價(jià)值。

  • 對(duì)于簡單的塊存儲(chǔ)用例,Longhorn絕對(duì)是有效的選擇,它與OpenEBS Jiva后端非常相似。

當(dāng)然,以上只是評(píng)測容器存儲(chǔ)選項(xiàng)的一種方法。存儲(chǔ)評(píng)測應(yīng)該還包括縮放和穩(wěn)定性等。后期將密切關(guān)注CNCF存儲(chǔ)領(lǐng)域中其他正在發(fā)展的項(xiàng)目,并從性能測試和擴(kuò)展中帶來跟多有趣的更新。

參考鏈接

1.https://medium.com/volterra-io/kubernetes-storage-performance-comparison-9e993cb27271

2.https://medium.com/volterra-io/kubernetes-storage-performance-comparison-v2-2020-updated-1c0b69f0dcf4

責(zé)任編輯:xj

原文標(biāo)題:K8s最常見的存儲(chǔ)解決方案之性能評(píng)測

文章出處:【微信公眾號(hào):存儲(chǔ)社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 分布式
    +關(guān)注

    關(guān)注

    1

    文章

    913

    瀏覽量

    74568
  • 儲(chǔ)存
    +關(guān)注

    關(guān)注

    3

    文章

    201

    瀏覽量

    22396

原文標(biāo)題:K8s最常見的存儲(chǔ)解決方案之性能評(píng)測

文章出處:【微信號(hào):TopStorage,微信公眾號(hào):存儲(chǔ)加速器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    常見電位測量錯(cuò)誤及解決方案

    常見電位測量錯(cuò)誤及解決方案 1. 接觸不良 錯(cuò)誤描述: 在電位測量中,接觸不良是最常見的問題之一。這可能是由于探針接觸不良、氧化層、污垢或腐蝕造成的。 解決方案: 清潔探針和被測點(diǎn),確
    的頭像 發(fā)表于 12-28 14:08 ?179次閱讀

    PCBA加工常見質(zhì)量問題揭秘:焊接不良與解決方案

    的質(zhì)量問題不僅會(huì)影響產(chǎn)品的性能和可靠性,還可能對(duì)廠家的聲譽(yù)和利潤造成重大影響。本文將深入探討PCBA加工過程中常見的質(zhì)量問題,并分析其產(chǎn)生的原因及可能的解決方案。 PCBA加工中的常見質(zhì)量問題及
    的頭像 發(fā)表于 12-13 09:28 ?181次閱讀

    k8s和docker區(qū)別對(duì)比,哪個(gè)更強(qiáng)?

    部署、擴(kuò)展、管理和應(yīng)用生命周期管理能力,可實(shí)現(xiàn)高可用性和自動(dòng)伸縮,兩者常結(jié)合使用以優(yōu)化容器化和應(yīng)用管理。UU云小編將對(duì)k8s和docker區(qū)別進(jìn)行詳細(xì)對(duì)比:
    的頭像 發(fā)表于 12-11 13:55 ?147次閱讀

    k8s微服務(wù)架構(gòu)就是云原生嗎?兩者是什么關(guān)系

    k8s微服務(wù)架構(gòu)就是云原生嗎?K8s微服務(wù)架構(gòu)并不等同于云原生,但兩者之間存在密切的聯(lián)系。Kubernetes在云原生架構(gòu)中扮演著核心組件的角色,它簡化了容器化應(yīng)用程序的管理,提供了彈性、自動(dòng)化
    的頭像 發(fā)表于 11-25 09:39 ?177次閱讀

    混合云部署k8s集群方法有哪些?

    混合云部署k8s集群方法是首先需在本地與公有云分別建立K8s集群,并確保網(wǎng)絡(luò)連接。接著,配置kubeconfig文件連接兩集群,并安裝云服務(wù)插件以實(shí)現(xiàn)資源互通。然后,編寫Deployment文件部署應(yīng)用,并使用kubectl命令應(yīng)用至集群。最后,驗(yàn)證應(yīng)用狀態(tài)并監(jiān)控集群性能
    的頭像 發(fā)表于 11-07 09:37 ?164次閱讀

    k8s可以部署私有云嗎?私有云部署全攻略

    Kubernetes(簡稱K8S)可以部署私有云。Kubernetes是一個(gè)開源的容器編排引擎,能夠自動(dòng)化容器的部署、擴(kuò)展和管理,使得應(yīng)用可以在各種環(huán)境中高效運(yùn)行。通過使用Kubernetes,企業(yè)可以在自己的數(shù)據(jù)中心或私有云環(huán)境中搭建和管理容器化的應(yīng)用,實(shí)現(xiàn)高度的靈活性和可擴(kuò)展性。
    的頭像 發(fā)表于 10-25 09:32 ?193次閱讀

    k8s云原生開發(fā)要求

    Kubernetes(K8s)云原生開發(fā)對(duì)硬件有一定要求。CPU方面,建議至少配備2個(gè)邏輯核心,高性能CPU更佳。內(nèi)存至少4GB,但8GB或更高更推薦。存儲(chǔ)需至少20-30GB可用空間
    的頭像 發(fā)表于 10-24 10:03 ?243次閱讀
    <b class='flag-5'>k8s</b>云原生開發(fā)要求

    k8s容器啟動(dòng)失敗的常見原因及解決辦法

    k8s容器啟動(dòng)失敗的問題通常出現(xiàn)在開發(fā)者使用Kubernetes進(jìn)行容器編排時(shí),可能的原因有多種,例如:配置錯(cuò)誤、鏡像問題、資源限制、依賴問題、網(wǎng)絡(luò)問題、節(jié)點(diǎn)狀態(tài)異常、其他因素等,以下是對(duì)這些常見原因的詳細(xì)分析:
    的頭像 發(fā)表于 10-11 10:12 ?291次閱讀

    云服務(wù)器部署k8s需要什么配置?

    云服務(wù)器部署K8s需要至少2核CPU、4GB內(nèi)存、50GBSSD存儲(chǔ)的主節(jié)點(diǎn)用于管理集群,工作節(jié)點(diǎn)建議至少2核CPU、2GB內(nèi)存、20GBSSD。還需安裝Docker,選擇兼容的Kubernetes版本,配置網(wǎng)絡(luò)插件,以及確保系統(tǒng)安全、監(jiān)控和備份措施到位。
    的頭像 發(fā)表于 10-09 15:31 ?224次閱讀

    納尼?自建K8s集群日志收集還能通過JMQ保存到JES

    作者:京東科技 劉恩浩 一、背景 基于K8s集群的私有化交付方案中,日志收集采用了ilogtail+logstash+kafka+es方案,其中ilogtail負(fù)責(zé)日志收集,logstash負(fù)責(zé)對(duì)數(shù)
    的頭像 發(fā)表于 09-30 14:45 ?232次閱讀

    常用的k8s容器網(wǎng)絡(luò)模式有哪些?

    常用的k8s容器網(wǎng)絡(luò)模式包括Bridge模式、Host模式、Overlay模式、Flannel模式、CNI(ContainerNetworkInterface)模式。K8s的容器網(wǎng)絡(luò)模式多種多樣
    的頭像 發(fā)表于 09-19 11:29 ?267次閱讀

    基于DPU與SmartNIC的K8s Service解決方案

    1.? 方案背景 1.1. Kubernetes Service介紹 Kubernetes Service是Kubernetes中的一個(gè)核心概念,它定義了一種抽象,用于表示一組提供相同功能的Pods
    的頭像 發(fā)表于 09-02 17:01 ?976次閱讀
    基于DPU與SmartNIC的<b class='flag-5'>K8s</b> Service<b class='flag-5'>解決方案</b>

    K8S學(xué)習(xí)教程三:在PetaExpress KubeSphere 容器部署 Wiki 系統(tǒng) wiki.js 并啟用中文全文檢索

    K8S學(xué)習(xí)教程(三):在PetaExpress KubeSphere 容器部署 Wiki 系統(tǒng) wiki.js 并啟用中文全文檢索? 。
    的頭像 發(fā)表于 07-08 17:03 ?668次閱讀
    <b class='flag-5'>K8S</b>學(xué)習(xí)教程三:在PetaExpress KubeSphere 容器部署 Wiki 系統(tǒng) wiki.js 并啟用中文全文檢索

    K8S學(xué)習(xí)教程(二):在 PetaExpress KubeSphere容器平臺(tái)部署高可用 Redis 集群

    并且需要手動(dòng)重啟節(jié)點(diǎn),相較之下,使用 PetaExpress 提供的 Kubernetes(k8s) 服務(wù) 進(jìn)行 Redis 集群的部署,則展現(xiàn)出了顯著的優(yōu)勢: 1、安裝便捷:使用鏡像或者 yaml 配置文件即可一件安裝,極大地簡化了安裝流程 2、縮擴(kuò)容方便:在 擴(kuò)容 、 縮容 方面的優(yōu)點(diǎn)一鍵伸縮,
    的頭像 發(fā)表于 07-03 15:30 ?808次閱讀
    <b class='flag-5'>K8S</b>學(xué)習(xí)教程(二):在 PetaExpress KubeSphere容器平臺(tái)部署高<b class='flag-5'>可用</b> Redis 集群

    基于 NXP S32K311 評(píng)估板的方案

    方案是以 NXP S32K311 芯片為主控制器的評(píng)估方案,S32K311 是基于 ARM Cortex-M7 的嵌入式應(yīng)用微控制器,有
    的頭像 發(fā)表于 02-18 11:22 ?906次閱讀
    基于 NXP <b class='flag-5'>S32K</b>311 <b class='flag-5'>評(píng)估</b>板的<b class='flag-5'>方案</b>