이 페이지에서는 데이터로 채워진 기존 영구 디스크를 사용하여 PersistentVolume을 만드는 방법과 pod에서 PersistentVolume을 사용하는 방법에 대해 설명합니다.
개요
기존 영구 디스크를 사용하는 두 가지 일반적인 시나리오가 있습니다.
- PersistentVolumeClaim과 PersistentVolume을 수동으로 만들고 서로 바인딩하여 포드 사양에서 PersistentVolumeClaim을 참조합니다.
- StatefulSet를 사용하여 일련의 기존 영구 디스크에 해당하는 수동으로 생성된 PersistentVolume에 바인딩된 PersistentVolumeClaim을 자동으로 생성합니다.
이 페이지의 예시에서는 기존 Compute Engine 영구 디스크를 사용합니다.
ext4
가 기본 파일 시스템 유형이지만 노드 이미지가 지원하는 경우 기존 영구 디스크를 xfs
파일 시스템과 함께 사용할 수 있습니다. xfs
디스크를 사용하려면 PersistentVolume 매니페스트에서 spec.csi.fsType
을 xfs
로 변경합니다.
Windows는 ext4
파일 시스템 유형을 지원하지 않습니다. Windows Server 노드 풀에는 NTFS
파일 시스템을 사용해야 합니다.
NTFS
디스크를 사용하려면 PersistentVolume 매니페스트에서 spec.csi.fsType
을 NTFS
로 변경합니다.
시작하기 전에
시작하기 전에 다음 태스크를 수행했는지 확인합니다.
- Google Kubernetes Engine API를 사용 설정합니다. Google Kubernetes Engine API 사용 설정
- 이 태스크에 Google Cloud CLI를 사용하려면 gcloud CLI를 설치한 후 초기화합니다. 이전에 gcloud CLI를 설치한 경우
gcloud components update
를 실행하여 최신 버전을 가져옵니다.
- 기존 영구 디스크가 있는지 확인합니다. 디스크를 프로비저닝하려면 리전 영구 디스크 프로비저닝을 참조하세요.
- 클러스터에서 Compute Engine 영구 디스크 CSI 드라이버를 사용하는지 확인합니다.
PersistentVolume에 바인딩된 PersistentVolumeClaim 사용
컨테이너가 기존 영구 디스크에 액세스하려면 다음을 수행해야 합니다.
- 기존 영구 디스크를 PersistentVolume으로 프로비저닝
- PersistentVolume을 PersistentVolumeClaim에 바인딩
- 포드의 컨테이너에 PersistentVolume에 대한 액세스 권한 부여
PersistentVolume 및 PersistentVolumeClaim 만들기
PersistentVolumeClaim을 특정 PersistentVolume에 바인딩하는 몇 가지 방법이 있습니다. 예를 들어 다음 YAML 매니페스트는 새 PersistentVolume 및 PersistentVolumeClaim을 만든 후 PersistentVolume이 해당 PersistentVolumeClaim에만 바인딩되도록 claimRef
를 사용하여 볼륨에 클레임을 바인딩합니다.
PersistentVolume을 PersistentVolumeClaim에 바인딩하려면 두 리소스의 storageClassName
이 capacity
, accessModes
, volumeMode
와 일치해야 합니다. storageClassName
을 생략할 수 있지만 Kubernetes에서 기본 StorageClass를 사용하지 못하도록 하려면 ""
를 지정해야 합니다.
storageClassName
는 기존 StorageClass 객체를 참조할 필요가 없습니다. 클레임을 볼륨에 바인딩해야 하는 경우 원하는 이름을 사용하면 됩니다. 그러나 볼륨 크기 조정과 같이 StorageClass에서 구성한 추가 기능이 필요한 경우 storageClassName
은 기존 StorageClass 객체를 참조해야 합니다.
자세한 내용은 PersistentVolumes 관련 Kubernetes 문서를 참조하세요.
다음 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
로 변경해야 합니다.
구성을 적용하고 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에 볼륨을 마운트합니다.
- 새 StatefulSet 이름, PersistentVolumeClaim 템플릿 이름, StatefulSet의 복제본 수를 결정합니다.
자동으로 생성된 PersistentVolumeClaim의 이름을 지정합니다. StatefulSet은 PersistentVolumeClaim 이름에 다음 형식을 사용합니다.
PVC_TEMPLATE_NAME-STATEFULSET_NAME-REPLICA_INDEX
다음을 바꿉니다.
PVC_TEMPLATE_NAME
: 새 PersistentVolumeClaim 템플릿 이름입니다.STATEFULSET_NAME
: 새 StatefulSet 이름입니다.REPLICA_INDEX
: StatefulSet의 복제본 색인입니다. 이 예시에서는0
및1
을 사용합니다.
PersistentVolume을 만듭니다. StatefulSet의 복제본마다 PersistentVolume을 만들어야 합니다.
다음 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 이름입니다.
구성을 적용합니다.
kubectl apply -f FILE_PATH
FILE_PATH
를 YAML 파일의 경로로 바꿉니다.
1단계에서 선택한 값을 사용하여 StatefulSet을 만듭니다.
volumeClaimTemplates
에 지정한 스토리지가 PersistentVolume의 총 용량보다 작거나 같은지 확인합니다.다음 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 이름입니다.
구성을 적용합니다.
kubectl apply -f FILE_PATH
FILE_PATH
를 YAML 파일의 경로로 바꿉니다.