文档首页/ 云容器引擎 CCE/ 用户指南/ 存储管理-Flexvolume(已弃用)/ 文件存储卷/ 使用kubectl部署带文件存储卷的有状态工作负载
更新时间:2024-08-17 GMT+08:00

使用kubectl部署带文件存储卷的有状态工作负载

操作场景

CCE支持使用已有的文件存储(PersistentVolumeClaim),创建有状态工作负载(StatefulSet)

约束与限制

如下配置示例适用于Kubernetes 1.13及以下版本的集群。

操作步骤

  1. 参照使用kubectl自动创建文件存储中操作创建文件存储卷,记录文件存储卷名称。
  2. 请参见通过kubectl连接集群,使用kubectl连接集群。
  3. 新建一个YAML文件,用于创建工作负载。假设文件名为sfs-statefulset-example.yaml

    touch sfs-statefulset-example.yaml

    vi sfs-statefulset-example.yaml

    yaml示例如下:

    apiVersion: apps/v1
    kind: StatefulSet
    metadata:
      name: sfs-statefulset-example
      namespace: default
    spec:
      replicas: 2
      selector:
        matchLabels:
          app: sfs-statefulset-example
      serviceName: qwqq
      template:
        metadata:
          annotations:
            metrics.alpha.kubernetes.io/custom-endpoints: '[{"api":"","path":"","port":"","names":""}]'
            pod.alpha.kubernetes.io/initialized: "true"
          labels:
            app: sfs-statefulset-example
        spec:
          affinity: {}
          containers:
          - image: nginx:latest
            name: container-0
            volumeMounts:
            - mountPath: /tmp
              name: pvc-sfs-example
          imagePullSecrets:
          - name: default-secret
          volumes:
            - name: pvc-sfs-example
              persistentVolumeClaim:
                claimName: cce-sfs-demo
    表1 关键参数说明

    前置路径

    参数

    描述

    spec

    replicas

    实例数。

    metadata

    name

    新建工作负载的名称。

    spec.template.spec.containers

    image

    新建工作负载使用的镜像。

    spec.template.spec.containers.volumeMounts

    mountPath

    容器内挂载路径。

    spec

    serviceName

    工作负载对应的服务,服务创建过程请参见创建有状态负载(StatefulSet)

    spec.template.spec.volumes.persistentVolumeClaim

    claimName

    已有PVC名称。

    spec.template.spec.containers.volumeMounts.name和spec.template.spec.volumes.name有映射关系,必须保持一致。

  4. 创建有状态工作负载。

    kubectl create -f sfs-statefulset-example .yaml