Erstellen Sie eine Speicherklasse
Konfigurieren Sie ein Kubernetes StorageClass-Objekt und erstellen Sie die Speicherklasse, um Trident anzuweisen, wie Volumes bereitgestellt werden sollen.
Konfigurieren eines Kubernetes StorageClass Objekts
Das "Kubernetes StorageClass-Objekt" identifiziert Trident als den Provisioner, der für diese Klasse verwendet wird, und weist Trident an, wie ein Volume bereitgestellt werden soll. Zum Beispiel:
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
name: ontap-gold
provisioner: csi.trident.netapp.io
mountOptions:
- nfsvers=3
- nolock
parameters:
backendType: "ontap-nas"
media: "ssd"
allowVolumeExpansion: true
volumeBindingMode: Immediate
Siehe "Kubernetes- und Trident-Objekte" für Details dazu, wie Storage-Klassen mit dem PersistentVolumeClaim interagieren und Parameter zur Steuerung, wie Trident Volumes bereitstellt.
Erstellen Sie eine Speicherklasse
Nachdem Sie das StorageClass-Objekt erstellt haben, können Sie die Speicherklasse erstellen. Storage-Class-Beispiele bietet einige grundlegende Beispiele, die Sie verwenden oder anpassen können.
-
Dies ist ein Kubernetes-Objekt, daher verwenden Sie
kubectl, um es in Kubernetes zu erstellen.kubectl create -f sample-input/storage-class-basic-csi.yaml
-
Sie sollten nun eine basic-csi Storage-Class sowohl in Kubernetes als auch in Trident sehen, und Trident sollte die Pools im Backend erkannt haben.
kubectl get sc basic-csi
NAME PROVISIONER AGE basic-csi csi.trident.netapp.io 15h
./tridentctl -n trident get storageclass basic-csi -o json
{
"items": [
{
"Config": {
"version": "1",
"name": "basic-csi",
"attributes": {
"backendType": "ontap-nas"
},
"storagePools": null,
"additionalStoragePools": null
},
"storage": {
"ontapnas_10.0.0.1": [
"aggr1",
"aggr2",
"aggr3",
"aggr4"
]
}
}
]
}
Storage-Class-Beispiele
Trident bietet "einfache Speicherklassendefinitionen für spezifische Backends".
Alternativ können Sie die sample-input/storage-class-csi.yaml.templ Datei, die mit dem Installationsprogramm geliefert wird, bearbeiten und BACKEND_TYPE durch den Namen des Speichertreibers ersetzen.
./tridentctl -n trident get backend +-------------+----------------+--------------------------------------+--------+---------+ | NAME | STORAGE DRIVER | UUID | STATE | VOLUMES | +-------------+----------------+--------------------------------------+--------+---------+ | nas-backend | ontap-nas | 98e19b74-aec7-4a3d-8dcf-128e5033b214 | online | 0 | +-------------+----------------+--------------------------------------+--------+---------+ cp sample-input/storage-class-csi.yaml.templ sample-input/storage-class-basic-csi.yaml # Modify __BACKEND_TYPE__ with the storage driver field above (e.g., ontap-nas) vi sample-input/storage-class-basic-csi.yaml