使用云硬盤靜態存儲卷
更新時間 2025-07-11 17:50:06
最近更新時間: 2025-07-11 17:50:06
分享文章
本文介紹如何使用云硬盤靜態存儲卷。
使用云盤靜態存儲卷,即使用預先在云硬盤控制臺已建好的云盤實例,通過手動創建PV,創建PVC時使用已有PV的方式,實現容器內掛載云盤存儲。
該模式下需要用戶自建云盤及PV資源,一定程度上增加操作和管理復雜性,一般推薦使用動態創建存儲的方式。
前提條件
確保您已經創建Serverless集群,具體操作請參閱創建Serverless集群。若已有Serverless集群,無需重復操作。
已在插件市場安裝存儲插件cstor-csi,且插件正常運行。
已在云硬盤控制臺創建云盤。
確保kubectl工具已經連接目標集群。
使用云盤靜態存儲卷(kubectl)
步驟一:創建持久卷(PV)
創建示例yaml文件pv-static-disk.yaml:
apiVersion: v1
kind: PersistentVolume
metadata:
annotations:
pv.kubernetes.io/provisioned-by: disk.csi.cstor.com
name: pvc-{PV-NAME} #PV的名稱,以pvc-開頭
spec:
accessModes:
- ReadWriteOnce #訪問模式
capacity:
storage: 10Gi #云盤容量
csi:
driver: disk.csi.cstor.com
fsType: ext4 #掛載類型
volumeAttributes:
diskUUID: {YOUR-DISK-UUID} #替換云盤ID
driverType: disk.csi.cstor.com
mode: VBD
shared: "false" #是否共享盤
type: SATA # 磁盤類型
volumeHandle: 0103-{PV-NAME-LENTH}-{PV-NAME} #PV-NAME-LENTH為PV-NAME長度的十六進制表示,比如PV-NAME是"pv-static-disk",則PV-NAME-LENTH為0E
mountOptions:
- discard
nodeAffinity:
required:
nodeSelectorTerms:
- matchExpressions:
- key: topology.disk.csi.cstor.com/zone
operator: In
values:
- <your-node-zone-id> #替換為您待部署應用的節點所在的可用區,例如cn-huadong1-jsnj1A-public-ctcloud
volumeMode: Filesystem #卷模式執行以下命令,創建pv:
kubectl apply -f pv-static-disk.yaml步驟二:創建持久卷聲明(PVC)
創建示例yaml文件pvc-static-disk.yaml:
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
annotations:
volume.beta.kubernetes.io/storage-provisioner: disk.csi.cstor.com
name: pvc-static-disk
namespace: default
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 10Gi
volumeMode: Filesystem
volumeName: {YOUR-PV-NAME} #替換PV名稱
執行以下命令,創建pvc:
kubectl apply -f pvc-static-disk.yaml
步驟三:創建工作負載
創建示例yaml文件pod-pvc-static-disk.yaml:
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: nginx-pvc-static-disk
labels:
app: nginx
spec:
replicas: 1
selector:
matchLabels:
app: nginx-pvc-static-disk
serviceName: ""
template:
metadata:
labels:
app: nginx-pvc-static-disk
spec:
containers:
- image: "registry-huadong1.crs-internal.daliqc.cn/open-source/nginx:1.26-alpine-slim"
imagePullPolicy: "IfNotPresent"
name: "nginx"
resources:
limits:
cpu: "100m"
memory: "256Mi"
requests:
cpu: "100m"
memory: "256Mi"
volumeMounts:
- mountPath: "/mnt/data"
name: "volume1"
volumes:
- name: "volume1"
persistentVolumeClaim:
claimName: "pvc-static-disk"
執行以下命令,創建StatefulSet:
kubectl apply -f pod-pvc-static-disk.yaml
步驟四:驗證數據持久化
登錄彈性容器服務管理控制臺。
在容器組列表頁點擊剛才創建的實例。
點擊“遠程連接”頁簽,進入到容器內。
向/mnt/data 目錄下寫一個文件,執行:
echo "Hello World" > /mnt/data/test.log
查看/mnt/data 目錄下文件,執行:
cat /mnt/data/test.log
預期結果如下:
退出“遠程連接”,使用kubectl刪除pod,會觸發pod自動重建,等待Pod重新運行正常。
kubectl delete po nginx-pvc-static-disk-0
對新建Pod,登錄彈性容器服務管理控制臺,繼續執行“遠程連接”,進入到容器內查看數據。執行:
cat /mnt/data/test.log
預期結果如下:
以上步驟說明,pod刪除重建后,重新掛載云盤,數據仍然存在,說明云硬盤中的數據可持久化保存。