기존 영구 디스크를 PersistentVolume으로 사용


이 페이지에서는 데이터로 채워진 기존 영구 디스크를 사용하여 PersistentVolume을 만드는 방법과 pod에서 PersistentVolume을 사용하는 방법에 대해 설명합니다.

개요

기존 영구 디스크를 사용하는 두 가지 일반적인 시나리오가 있습니다.

이 페이지의 예시에서는 기존 Compute Engine 영구 디스크를 사용합니다.

ext4가 기본 파일 시스템 유형이지만 노드 이미지가 지원하는 경우 기존 영구 디스크를 xfs 파일 시스템과 함께 사용할 수 있습니다. xfs 디스크를 사용하려면 PersistentVolume 매니페스트에서 spec.csi.fsTypexfs로 변경합니다.

Windows는 ext4 파일 시스템 유형을 지원하지 않습니다. Windows Server 노드 풀에는 NTFS 파일 시스템을 사용해야 합니다. NTFS 디스크를 사용하려면 PersistentVolume 매니페스트에서 spec.csi.fsTypeNTFS로 변경합니다.

시작하기 전에

시작하기 전에 다음 태스크를 수행했는지 확인합니다.

  • Google Kubernetes Engine API를 사용 설정합니다.
  • Google Kubernetes Engine API 사용 설정
  • 이 태스크에 Google Cloud CLI를 사용하려면 gcloud CLI를 설치한 후 초기화합니다. 이전에 gcloud CLI를 설치한 경우 gcloud components update를 실행하여 최신 버전을 가져옵니다.

PersistentVolume에 바인딩된 PersistentVolumeClaim 사용

컨테이너가 기존 영구 디스크에 액세스하려면 다음을 수행해야 합니다.

  1. 기존 영구 디스크를 PersistentVolume으로 프로비저닝
  2. PersistentVolume을 PersistentVolumeClaim에 바인딩
  3. 포드의 컨테이너에 PersistentVolume에 대한 액세스 권한 부여

PersistentVolume 및 PersistentVolumeClaim 만들기

PersistentVolumeClaim을 특정 PersistentVolume에 바인딩하는 몇 가지 방법이 있습니다. 예를 들어 다음 YAML 매니페스트는 새 PersistentVolume 및 PersistentVolumeClaim을 만든 후 PersistentVolume이 해당 PersistentVolumeClaim에만 바인딩되도록 claimRef를 사용하여 볼륨에 클레임을 바인딩합니다.

PersistentVolume을 PersistentVolumeClaim에 바인딩하려면 두 리소스의 storageClassNamecapacity, accessModes, volumeMode와 일치해야 합니다. storageClassName을 생략할 수 있지만 Kubernetes에서 기본 StorageClass를 사용하지 못하도록 하려면 ""를 지정해야 합니다.

storageClassName는 기존 StorageClass 객체를 참조할 필요가 없습니다. 클레임을 볼륨에 바인딩해야 하는 경우 원하는 이름을 사용하면 됩니다. 그러나 볼륨 크기 조정과 같이 StorageClass에서 구성한 추가 기능이 필요한 경우 storageClassName은 기존 StorageClass 객체를 참조해야 합니다.

자세한 내용은 PersistentVolumes 관련 Kubernetes 문서를 참조하세요.

  1. 다음 YAML 매니페스트를 저장합니다.

    apiVersion: v1
    kind: PersistentVolume
    metadata:
      name: PV_NAME
    spec:
      storageClassName: "STORAGE_CLASS_NAME"
      capacity:
        storage: DISK_SIZE
      accessModes:
        - ReadWriteOnce
      claimRef:
        namespace: default
        name: PV_CLAIM_NAME
      csi:
        driver: pd.csi.storage.gke.io
        volumeHandle: DISK_ID
        fsType: FS_TYPE
    ---
    apiVersion: v1
    kind: PersistentVolumeClaim
    metadata:
      namespace: default
      name: PV_CLAIM_NAME
    spec:
      storageClassName: "STORAGE_CLASS_NAME"
      volumeName: PV_NAME
      accessModes:
        - ReadWriteOnce
      resources:
        requests:
          storage: DISK_SIZE
    

    다음을 바꿉니다.

    • PV_NAME: 새 PersistentVolume 이름입니다.
    • STORAGE_CLASS_NAME: 새 StorageClass의 이름입니다.
    • DISK_SIZE: 기존 영구 디스크의 크기입니다. 예를 들면 500G입니다.
    • PV_CLAIM_NAME: 새 PersistentVolumeClaim 이름입니다.
    • DISK_ID: 기존 영구 디스크의 식별자입니다. 형식은 영역 영구 디스크의 경우 projects/{project_id}/zones/{zone_name}/disks/{disk_name}, 리전 영구 디스크의 경우 projects/{project_id}/regions/{region_name}/disks/{disk_name}입니다.
    • FS_TYPE: 파일 시스템 유형입니다. 기본값(ext4)으로 그대로 두거나 xfs를 사용합니다. 클러스터에서 Windows Server 노드 풀을 사용하는 경우 NTFS로 변경해야 합니다.
  2. 구성을 적용하고 PersistentVolume 및 PersistentVolumeClaim 리소스를 만들려면 다음 명령어를 실행합니다.

    kubectl apply -f FILE_PATH
    

    FILE_PATH를 YAML 파일의 경로로 바꿉니다.

포드에서 PersistentVolume 사용

PersistentVolume 및 PersistentVolumeClaim을 만들고 바인딩한 후 volumeMounts 필드에 값을 지정하여 포드의 컨테이너에 볼륨 액세스 권한을 부여할 수 있습니다.

다음 YAML 구성은 새 포드 및 nginx 이미지를 실행하는 컨테이너를 만든 후 포드에 PersistentVolume을 마운트합니다.

kind: Pod
apiVersion: v1
metadata:
  name: POD_NAME
spec:
  volumes:
    - name: VOLUME_NAME
      persistentVolumeClaim:
        claimName: PV_CLAIM_NAME
  containers:
    - name: CONTAINER_NAME
      image: nginx
      ports:
        - containerPort: 80
          name: "http-server"
      volumeMounts:
        - mountPath: "/usr/share/nginx/html"
          name: VOLUME_NAME

다음을 바꿉니다.

  • POD_NAME: 새 포드 이름입니다.
  • VOLUME_NAME: 볼륨 이름입니다.
  • PV_CLAIM_NAME: 이전 단계에서 만든 PersistentVolumeClaim의 이름입니다.
  • CONTAINER_NAME: 새 컨테이너 이름입니다.

구성을 적용합니다.

kubectl apply -f FILE_PATH

FILE_PATH를 YAML 파일의 경로로 바꿉니다.

볼륨이 마운트되었는지 확인하려면 다음 명령어를 실행합니다.

kubectl describe pods POD_NAME

출력에서 PersistentVolumeClaim이 마운트되었는지 확인합니다.

...
Volumes:
  VOLUME_NAME:
    Type:       PersistentVolumeClaim (a reference to a PersistentVolumeClaim in the same namespace)
    ClaimName:  PV_CLAIM_NAME
    ReadOnly:   false
Events:
  Type    Reason                  Age   From                     Message
  ----    ------                  ----  ----                     -------
  Normal  Scheduled               29s   default-scheduler        Successfully assigned default/POD_NAME to gke-cluster-1-default-pool-d5cde866-o4g4
  Normal  SuccessfulAttachVolume  21s   attachdetach-controller  AttachVolume.Attach succeeded for volume "PV_NAME"
  Normal  Pulling                 19s   kubelet                  Pulling image "nginx"
  Normal  Pulled                  19s   kubelet                  Successfully pulled image "nginx"
  Normal  Created                 18s   kubelet                  Created container CONTAINER_NAME
  Normal  Started                 18s   kubelet                  Started container CONTAINER_NAME

StatefulSet에서 기존 디스크 사용

PersistentVolume을 사용하여 StatefulSet에서 기존 Compute Engine 영구 디스크를 사용할 수 있습니다. StatefulSet은 복제본마다 자동으로 PersistentVolumeClaim을 생성합니다. 생성된 PersistentVolumeClaims의 이름을 예측하고 claimRef를 사용하여 PersistentVolume에 바인딩할 수 있습니다.

다음 예시에서는 기존 영구 디스크 두 개를 선택하고 디스크를 사용하도록 PersistentVolume을 만든 후 기본 네임스페이스에 복제본 두 개가 있는 StatefulSet에 볼륨을 마운트합니다.

  1. 새 StatefulSet 이름, PersistentVolumeClaim 템플릿 이름, StatefulSet의 복제본 수를 결정합니다.
  2. 자동으로 생성된 PersistentVolumeClaim의 이름을 지정합니다. StatefulSet은 PersistentVolumeClaim 이름에 다음 형식을 사용합니다.

    PVC_TEMPLATE_NAME-STATEFULSET_NAME-REPLICA_INDEX
    

    다음을 바꿉니다.

    • PVC_TEMPLATE_NAME: 새 PersistentVolumeClaim 템플릿 이름입니다.
    • STATEFULSET_NAME: 새 StatefulSet 이름입니다.
    • REPLICA_INDEX: StatefulSet의 복제본 색인입니다. 이 예시에서는 01을 사용합니다.
  3. PersistentVolume을 만듭니다. StatefulSet의 복제본마다 PersistentVolume을 만들어야 합니다.

    1. 다음 YAML 매니페스트를 저장합니다.

      apiVersion: v1
      kind: PersistentVolume
      metadata:
        name: pv-ss-demo-0
      spec:
        storageClassName: "STORAGE_CLASS_NAME"
        capacity:
          storage: DISK1_SIZE
        accessModes:
          - ReadWriteOnce
        claimRef:
          namespace: default
          name: PVC_TEMPLATE_NAME-STATEFULSET_NAME-0
        csi:
          driver: pd.csi.storage.gke.io
          volumeHandle: DISK1_ID
          fsType: FS_TYPE
       ---
      apiVersion: v1
      kind: PersistentVolume
      metadata:
        name: pv-ss-demo-1
      spec:
        storageClassName: "STORAGE_CLASS_NAME"
        capacity:
          storage: DISK2_SIZE
        accessModes:
          - ReadWriteOnce
        claimRef:
          namespace: default
          name: PVC_TEMPLATE_NAME-STATEFULSET_NAME-1
        csi:
          driver: pd.csi.storage.gke.io
          volumeHandle: DISK2_ID
          fsType: FS_TYPE
      

      다음을 바꿉니다.

      • DISK1_SIZE and DISK2_SIZE: 기존 영구 디스크의 크기입니다.
      • DISK1_ID and DISK2_ID: 기존 영구 디스크의 식별자입니다.
      • PVC_TEMPLATE_NAME-STATEFULSET_NAME-0 and PVC_TEMPLATE_NAME-STATEFULSET_NAME-1: 이전 단계에서 정의된 형식을 따르는 자동으로 생성된 PersistentVolumeClaim의 이름입니다.
      • STORAGE_CLASS_NAME: StorageClass 이름입니다.
    2. 구성을 적용합니다.

      kubectl apply -f FILE_PATH
      

      FILE_PATH를 YAML 파일의 경로로 바꿉니다.

  4. 1단계에서 선택한 값을 사용하여 StatefulSet을 만듭니다. volumeClaimTemplates에 지정한 스토리지가 PersistentVolume의 총 용량보다 작거나 같은지 확인합니다.

    1. 다음 YAML 매니페스트를 저장합니다.

      apiVersion: apps/v1
      kind: StatefulSet
      metadata:
        name: STATEFULSET_NAME
      spec:
        selector:
          matchLabels:
            app: nginx
        serviceName: "nginx"
        replicas: 2
        template:
          metadata:
            labels:
              app: nginx
          spec:
            terminationGracePeriodSeconds: 10
            containers:
            - name: nginx
              image: registry.k8s.io/nginx-slim:0.8
              ports:
              - containerPort: 80
                name: web
              volumeMounts:
              - name: PVC_TEMPLATE_NAME
                mountPath: /usr/share/nginx/html
        volumeClaimTemplates:
        - metadata:
            name: PVC_TEMPLATE_NAME
          spec:
            accessModes: [ "ReadWriteOnce" ]
            storageClassName: "STORAGE_CLASS_NAME"
            resources:
              requests:
                storage: 100Gi
      

      다음을 바꿉니다.

      • STATEFULSET_NAME: 새 StatefulSet 이름입니다.
      • PVC_TEMPLATE_NAME: 새 PersistentVolumeClaim 템플릿 이름입니다.
      • STORAGE_CLASS_NAME: StorageClass 이름입니다.
    2. 구성을 적용합니다.

      kubectl apply -f FILE_PATH
      

      FILE_PATH를 YAML 파일의 경로로 바꿉니다.

다음 단계