CSP 별 스토리지(PV) 용량 증설 방법

인쇄

Overview

PV(PersistentVolume)의 용량을 증설하는 방법을 소개합니다.

AWS

AWS의 Block Storage 용량 증설 방법

AWS console에서의 증설 방법

1. AWS Console(https://aws.amazon.com/console/)로 접속하여 서비스에서 “EC2”를 선택 → Elastic Block Store의 “볼륨”을 선택 → volumeHandle(또는 PV name)로 검색 후 Size를 확인 하시기 바랍니다.

2. 상단의 “작업”을 버튼을 클릭한 후 “볼륨 수정”을 선택하시기 바랍니다.

3. 변경할 Size로 수정 후 “수정” 버튼을 클릭합니다.

4. 다시 한 번 확인하는 창이 뜨면 “예” 버튼을 클릭합니다.

<참고> 최근에 볼륨을 수정하였다면 6시간 후에 변경이 가능합니다.

5. 변경이 완료되었다는 메시지를 확인합니다.

6. 변경된 용량을 확인합니다.

용량 증설 후 file system 확장

1. 해당 PV가 연결된 pod이 떠 있는 instance에 접속

2. pvc의 용량 확인

# 변경 전의 용량(1GB)으로 표시
$ df -hT | grep pvc-7e095b59-b814-4737-b672-f6b014d6e335
/dev/nvme1n1   ext4      976M  198M  763M  21% /var/lib/kubelet/plugins/kubernetes.io/csi/pv/pvc-7e095b59-b814-4737-b672-f6b014d6e335/globalmount

3. 용량이 변경된 block device확인

# 변경 후
$ lsblk
NAME          MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
nvme0n1       259:0    0  100G  0 disk
├─nvme0n1p1   259:1    0  100G  0 part /
└─nvme0n1p128 259:2    0    1M  0 part
nvme1n1       259:3    0    2G  0 disk /var/lib/kubelet/pods/73c7b7c0-0cb4-4737-841c-4b0b01cb767e/volumes/kubernetes.io~csi/pvc-7e095b59-b814-4737-b672-f6b014d6e335/mount

4. 변경된 용량이 적용되도록 file system을 확장

# /dev/xvda1 부분은 file system name
sudo resize2fs /dev/xvda1

# 실행 예
$ sudo resize2fs /dev/nvme1n1
resize2fs 1.42.9 (28-Dec-2013)
Filesystem at /dev/nvme1n1 is mounted on /var/lib/kubelet/plugins/kubernetes.io/csi/pv/pvc-7e095b59-b814-4737-b672-f6b014d6e335/globalmount; on-line resizing required
old_desc_blocks = 1, new_desc_blocks = 1
The filesystem on /dev/nvme1n1 is now 524288 blocks long.

5. 정상적으로 적용되었는지 확인

$ df -hT | grep pvc-7e095b59-b814-4737-b672-f6b014d6e335
/dev/nvme1n1   ext4      2.0G  199M  1.8G  11% /var/lib/kubelet/plugins/kubernetes.io/csi/pv/pvc-7e095b59-b814-4737-b672-f6b014d6e335/globalmount

연결된 pod에도 들어가서 확인

df -h /consul/data
Filesystem                Size      Used Available Use% Mounted on
/dev/nvme1n1              1.9G    198.1M      1.7G  10% /consul/data

참고페이지

https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/recognize-expanded-volume-linux.html

PV와 PVC에 정의된 용량을 증설된 용량으로 표시되도록 변경

이 방법은 kubectl get pv나 kubectl get pvc로 확인하였을 때 증설된 용량으로 보이게 하기 위해서 필요합니다.

예전 용량으로 보이셔도 상관없다면 수행하지 않으셔도 됩니다.

[PV의 Reclaim Policy가 Retain인 경우]

1. PVC Backup

해당 PV의 PVC를 backup 합니다.

$ kubectl get pvc <PVC name> -o yaml > <저장하고자 하는 filename>.yaml

2. PVC yaml file 수정 <만일, Endurance의 IOPS도 변경했다면 storage-class도 변경할 것>

아래 3개의 부분을 증설된 용량으로 변경해서 저장

metadata > annotation > kubectl.kubernetes.io/last-applied-configuration

spec > resources > requests > storage

status > capacity > storage

$ vi <저장한 PVC filename>.yaml
...
    kubectl.kubernetes.io/last-applied-configuration: |
      {"apiVersion":"v1","kind":"PersistentVolumeClaim","metadata":{"annotations":{"kubernetes.io/change-cause":"kubectl apply --filename=k8s/prod/pvc.yaml --namespace=zcp-system --record=true","volume.beta.kubernetes.io/storage-class":"ibmc-block-retain-bronze"},"labels":{"billingType":"monthly"},"name":"pvc-test","namespace":"zcp-system"},"spec":{"accessModes":["ReadWriteOnce"],"resources":{"requests":{"storage":"30Gi"}}}}
...
spec:
...
  resources:
    requests:
      storage: 20Gi
...
status:
...
  capacity:
    storage: 30Gi
...

3. PVC Delete

$ kubectl delete pvc --force --grace-period=0 <PVC name>

4. PV 수정 <만일, Endurance의 IOPS도 변경했다면 storage-class도 변경할 것>

아래 2개의 부분을 증설된 용량으로 변경해서 저장합니다.

labels > CapacityGb

spec > capacity > storage

claimRef 부분은 삭제

$ kubectl edit pv <PV name>
...
  labels:
    CapacityGb: "30"
...
spec:
...
  capacity:
    storage: 30Gi
...

5. PV patch

$ kubectl patch pv <PV name> -p '{"metadata": {"annotations":{"ibm.io/autofix-resizefs":"true"}}}'

6. PVC create

Backup해둔 PVC yaml로 PVC를 생성합니다.

$ kubectl create -f <저장한 PVC filename>.yaml

[PV의 Reclaim Policy가 Delete인 경우] 

<주의> 아래 순서대로가 아닌 PVC를 먼저 삭제하게 되면 Storage가 삭제됨

1. PV, PVC backup

$ kubectl get pv <PV name> -o yaml > <저장하고자 하는 filename>.yaml

$ kubectl get pvc <PVC name> -o yaml > <저장하고자 하는 filename>.yaml

2. PV yaml 수정 <만일, Endurance의 IOPS도 변경했다면 storage-class도 변경할 것>

아래 2개의 부분을 증설된 용량으로 변경해서 저장합니다.

labels > CapacityGb

spec > capacity > storage

claimRef 부분은 삭제

$ vi <저장한 PV filename>.yaml
...
  labels:
    CapacityGb: "30"
...
spec:
...
  capacity:
    storage: 30Gi
...
  1. PVC yaml file 수정 <만일, Endurance의 IOPS도 변경했다면 storage-class도 변경할 것>

아래 3개의 부분을 증설된 용량으로 변경해서 저장합니다.

metadata > annotation > kubectl.kubernetes.io/last-applied-configuration

spec > resources > requests > storage

status > capacity > storage

$ vi <저장한 PVC filename>.yaml
...
    kubectl.kubernetes.io/last-applied-configuration: |
      {"apiVersion":"v1","kind":"PersistentVolumeClaim","metadata":{"annotations":{"kubernetes.io/change-cause":"kubectl apply --filename=k8s/prod/pvc.yaml --namespace=zcp-system --record=true","volume.beta.kubernetes.io/storage-class":"ibmc-block-bronze"},"labels":{"billingType":"monthly"},"name":"pvc-test","namespace":"zcp-system"},"spec":{"accessModes":["ReadWriteOnce"],"resources":{"requests":{"storage":"30Gi"}}}}...
spec:
...
  resources:
    requests:
      storage: 20Gi
...
status:
...
  capacity:
    storage: 20Gi
...

3. PV Delete

$ kubectl delete pv --force --grace-period=0 <PV name>

# 만일 위의 명령어 실행 후에도 상태가 Terminating가 계속 된다면 아래 patch 실행
$ kubectl patch pv <pvc name> -p '{"metadata":{"finalizers":null}}'

4. PVC Delete

$ kubectl delete pvc --force --grace-period=0 <PVC name>

5. PV create

Backup해둔 PV yaml로 PV를 생성합니다.

$ kubectl create -f <저장한 PV filename>.yaml

6. PVC create

Backup해둔 PVC yaml로 PVC를 생성합니다.

$ kubectl create -f <저장한 PVC filename>.yaml

7. PV patch

$ kubectl patch pv <PV name> -p '{"metadata": {"annotations":{"ibm.io/autofix-resizefs":"true"}}}'

kubectl에서의 용량 증설 방법

PVC에서 용량 증설

변경하고자 하는 PV의 PVC를 편집으로 연 후에 용량(5GB)을 증설하는 용량(6GB)으로 변경 후 저장합니다.

$ kubectl edit pvc zcp-oidc-postgresql
apiVersion: v1
kind: PersistentVolumeClaim
...
spec:
...
  resources:
    requests:
      storage: 5Gi
...

증설한 용량으로 변경이 되었는지 확인

kubectl CLI로 확인

  • PVC 용량 확인

$ kubectl get pvc -w
NAME                                                    STATUS   VOLUME                                     CAPACITY   ACCESS MODES   STORAGECLASS               AGE
elasticsearch-data-test-elasticsearch-data-test-0       Bound    pvc-xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx   200Gi      RWO            ibmc-block-retain-silver   21h
elasticsearch-data-test-elasticsearch-data-test-1       Bound    pvc-xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx   200Gi      RWO            ibmc-block-retain-silver   21h
elasticsearch-data-test-elasticsearch-data-test-2       Bound    pvc-xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx   200Gi      RWO            ibmc-block-retain-silver   21h
elasticsearch-data-test-elasticsearch-data-test-2       Bound    pvc-xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx   220Gi      RWO            ibmc-block-retain-silver   21h
  • PV 용량 확인

$ kubectl get pv
NAME                                       CAPACITY   ACCESS MODES   RECLAIM POLICY   STATUS      CLAIM                                                              STORAGECLASS               REASON   AGE
pvc-xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx   220Gi      RWO            Retain           Bound       zcp-system/elasticsearch-data-test-elasticsearch-data-test-2       ibmc-block-retain-silver            21h
  • 연결된 pod 재시작

  • pod에 들어가서 변경된 용량이 적용되었는지 확인합니다.

$ kubectl exec -it elasticsearch-data-test-2 bash
[root@elasticsearch-data-test-2 elasticsearch]# df -h
Filesystem                                     Size  Used Avail Use% Mounted on
...
/dev/mapper/3600a09803830446d463f4c454857636c  216G   60M  216G   1% /usr/share/elasticsearch/data
...

참고페이지

https://kubernetes.io/blog/2018/07/12/resizing-persistent-volumes-using-kubernetes/

https://kubernetes.io/docs/concepts/storage/persistent-volumes/#expanding-persistent-volumes-claims

AWS의 File Storage 용량 증설 방법

따로 증설할 필요가 없습니다.

AWS에서는 file Storage가 각각의 PV로 생성되는 것이 아니라 하나의 EFS를 생성하는 방식입니다.

file stroage를 생성하게 되면 EFS 안에 폴더가 생성되고, 생성 시 설정한 용량을 넘어서게 되면 늘어난 용량으로 자동적으로 증설됩니다. 참고로 EFS 전체 용량을 기준으로 과금 됩니다.

Azure

Azure의 Block Storage 용량 증설 방법

<주의> 용량 증설 전에 PV와 연결된 pod이 있으면 먼저 종료해주셔야 합니다.

1. Azure Console(https://portal.azure.com/ )에서 Resource groups → AKS resource group선택 → PV name로 검색 후 선택 → 용량을 확인 하시기 바랍니다.

2. Settings 하위 Size + performance를 클릭하십시오.

disk size를 변경을 원하는 용량으로 수정한 후 [Resize] 버튼을 클릭하십시오.

<주의> 사용 중인 disk 공간의 양에 관계없이 provisioning된 disk에 대해 동일한 요금이 청구됩니다.

예를 들어 200GiB disk는 256GiB disk에 provisioning되므로 provisioning 된 256GiB에 대해 비용이 청구됩니다.