使用云盘静态存储卷,即使用预先在云硬盘控制台已建好的云盘实例,通过手动创建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-static-disk #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-{length}-{name} # length为16进制的PV名字的后缀(不包含pvc-)的长度,示例是0E;name替换为PV名字的后缀(不包含pvc-),示例是pv-static-disk
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.ctyun.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删除重建后,重新挂载云盘,数据仍然存在,说明云硬盘中的数据可持久化保存。