您可以直接通过volume或者PV/PVC使用阿里云云盘存储卷。

前提条件

使用云盘数据卷之前,您需要先在ECS管理控制台上创建云盘。请参见创建云盘

直接通过volume使用

使用disk-deploy.yaml文件创建Pod。

  1. 创建disk-deploy.yaml文件,然后拷贝以下内容到文件中。
    apiVersion: v1
    kind: Service
    metadata:
      name: nginx
      labels:
        app: nginx
    spec:
      ports:
      - port: 80
        name: web
      clusterIP: None
      selector:
        app: nginx
    ---
    apiVersion: apps/v1
    kind: StatefulSet
    metadata:
      name: web
    spec:
      selector:
        matchLabels:
          app: nginx
      serviceName: "nginx"
      template:
        metadata:
          labels:
            app: nginx
        spec:
          containers:
          - name: nginx
            image: nginx
            ports:
            - containerPort: 80
              name: web
            volumeMounts:
            - name: d-wz9f6l6nm0uvazgh7y17
              mountPath: /data
          volumes:
            - name: "d-wz9f6l6nm0uvazgh7y17"
              flexVolume:
                driver: "alicloud/disk"
                fsType: "ext4"
                options:
                  volumeId: "d-wz9f6l6nm0uvazgh7y17"
  2. 执行如下命令,创建Pod。
    kubectl apply -f disk-deploy.yaml
说明

volumes中,name的取值建议和volumeId的取值保持一致。

如果您所使用的集群是多可用区的模式,使用云盘时需要进行可用区调度,即把Pod调度到与云盘相同的可用区。具体配置为在yaml中对pod添加nodeSelector,示例如下。
nodeSelector:
        failure-domain.beta.kubernetes.io/zone: cn-hangzhou-b

通过PV/PVC使用

  1. 创建云盘类型的PV。
    您可以使用yaml文件或者控制台界面创建云盘类型的PV。
    • 通过yaml文件创建PV。
      使用disk-pv.yaml文件创建PV。
      apiVersion: v1
      kind: PersistentVolume
      metadata:
        name: d-bp1j17ifxfasvts3****
        labels:
          failure-domain.beta.kubernetes.io/zone: cn-hangzhou-b
          failure-domain.beta.kubernetes.io/region: cn-hangzhou
      spec:
        capacity:
          storage: 20Gi
        storageClassName: disk
        accessModes:
          - ReadWriteOnce
        flexVolume:
          driver: "alicloud/disk"
          fsType: "ext4"
          options:
            volumeId: "d-bp1j17ifxfasvts3****"
      说明 PV的名称(name)要与阿里云盘ID (volumeId)的取值保持一致。
    • 通过控制台界面创建云盘数据卷 。
      1. 登录容器服务管理控制台
      2. 在控制台左侧导航栏中,单击集群
      3. 集群列表页面中,单击目标集群名称或者目标集群右侧操作列下的详情
      4. 在集群管理页左侧导航栏中,单击存储卷
      5. 存储卷页签,单击创建
      6. 创建数据卷对话框中,配置数据卷的相关参数。
        参数名 描述
        存储卷类型 本示例中为云盘
        存储驱动 本示例中为Flexvolume
        访问模式 默认为ReadWriteOnce。
        云盘ID 您可以选择与集群属于相同地域和可用区下处于待挂载状态的云盘。
        文件系统类型 您可以选择以什么数据类型将数据存储到云盘上,支持的类型包括ext4、ext3、xfs、vfat。默认为ext4。
        标签 为该数据卷添加标签。
      7. 完成配置后,单击创建
  2. 创建PVC。
    使用disk-pvc.yaml文件创建PVC。
    kind: PersistentVolumeClaim
    apiVersion: v1
    metadata:
      name: pvc-disk
    spec:
      accessModes:
        - ReadWriteOnce
      storageClassName: disk
      resources:
        requests:
          storage: 20Gi
  3. 创建Pod。
    使用disk-pod.yaml文件创建Pod。
    apiVersion: v1
    kind: Service
    metadata:
      name: nginx
      labels:
        app: nginx
    spec:
      ports:
      - port: 80
        name: web
      clusterIP: None
      selector:
        app: nginx
    ---
    apiVersion: apps/v1
    kind: StatefulSet
    metadata:
      name: web
    spec:
      selector:
        matchLabels:
          app: nginx
      serviceName: "nginx"
      template:
        metadata:
          labels:
            app: nginx
        spec:
          containers:
          - name: nginx
            image: nginx
            ports:
            - containerPort: 80
              name: web
            volumeMounts:
            - name: pvc-disk
              mountPath: /data
          volumes:
            - name: pvc-disk
              persistentVolumeClaim:
                claimName: pvc-disk