5.16. Google Compute Platform Filestore CSI Driver Operator
5.16.1. 개요
OpenShift Container Platform은 GCP(Google Compute Platform) Filestore Storage용 CSI(Container Storage Interface) 드라이버를 사용하여 PV(영구 볼륨)를 프로비저닝할 수 있습니다.
GCP Filestore CSI Driver Operator는 기술 프리뷰 기능 전용입니다. 기술 프리뷰 기능은 Red Hat 프로덕션 서비스 수준 계약(SLA)에서 지원되지 않으며 기능적으로 완전하지 않을 수 있습니다. 따라서 프로덕션 환경에서 사용하는 것은 권장하지 않습니다. 이러한 기능을 사용하면 향후 제품 기능을 조기에 이용할 수 있어 개발 과정에서 고객이 기능을 테스트하고 피드백을 제공할 수 있습니다.
Red Hat 기술 프리뷰 기능의 지원 범위에 대한 자세한 내용은 기술 프리뷰 기능 지원 범위를 참조하십시오.
CSI Operator 및 드라이버 를 사용할 때는 영구 스토리지 및 CSI 볼륨 구성에 대해 숙지하는 것이 좋습니다.
GCP Filestore Storage 자산에 마운트되는 CSI 프로비저닝 PV를 생성하려면 openshift-cluster-csi-drivers
네임스페이스에 GCP Filestore CSI Driver Operator 및 GCP Filestore CSI 드라이버를 설치합니다.
- GCP Filestore CSI Driver Operator 는 기본적으로 스토리지 클래스를 제공하지 않지만 필요한 경우 생성할 수 있습니다. GCP Filestore CSI Driver Operator는 필요에 따라 스토리지 볼륨을 생성할 수 있어 클러스터 관리자가 스토리지를 사전 프로비저닝할 필요가 없어 동적 볼륨 프로비저닝을 지원합니다.
- GCP Filestore CSI 드라이버 를 사용하면 GCP Filestore PV를 생성하고 마운트할 수 있습니다.
5.16.2. CSI 정보
스토리지 벤더는 일반적으로 Kubernetes의 일부로 스토리지 드라이버를 제공합니다. CSI(Container Storage Interface) 구현을 통해 타사 공급자는 코어 Kubernetes 코드를 변경하지 않고도 표준 인터페이스를 사용하여 스토리지 플러그인을 제공할 수 있습니다.
CSI Operator는 in-tree 볼륨 플러그인에서 사용할 수 없는 볼륨 스냅샷과 같은 OpenShift Container Platform 사용자 스토리지 옵션을 제공합니다.
5.16.3. GCP Filestore CSI Driver Operator 설치
GCP(Google Compute Platform) Filestore Container Storage Interface(CSI) Driver Operator가 기본적으로 OpenShift Container Platform에 설치되지 않습니다. 다음 절차에 따라 클러스터에 GCP Filestore CSI Driver Operator를 설치합니다.
사전 요구 사항
- OpenShift Container Platform 웹 콘솔에 액세스합니다.
절차
웹 콘솔에서 GCP Filestore CSI Driver Operator를 설치하려면 다음을 수행합니다.
- 웹 콘솔에 로그인합니다.
다음 명령을 실행하여 GCE 프로젝트에서 Filestore API를 활성화합니다.
$ gcloud services enable file.googleapis.com --project <my_gce_project> 1
- 1
- &
lt;my_gce_project>
;를 Google Cloud 프로젝트로 바꿉니다.
Google Cloud 웹 콘솔을 사용하여 이 작업을 수행할 수도 있습니다.
GCP Filestore CSI Operator를 설치합니다.
-
Operators
OperatorHub를 클릭합니다. - 필터 상자에서 GCP Filestore를 입력하여 GCP Filestore 를 찾습니다.
- GCP Filestore CSI Driver Operator 버튼을 클릭합니다.
- GCP Filestore CSI Driver Operator 페이지에서 설치를 클릭합니다.
Operator 설치 페이지에서 다음을 확인합니다.
- 클러스터의 모든 네임스페이스(기본값)가 선택됩니다.
- 설치된 네임스페이스는 openshift-cluster-csi-drivers로 설정됩니다.
설치를 클릭합니다.
설치가 완료되면 웹 콘솔의 설치된 Operator 섹션에 GCP Filestore CSI Operator 가 나열됩니다.
-
Operators
GCP Filestore CSI 드라이버를 설치합니다.
-
관리
CustomResourceDefinitions ClusterCSIDriver를 클릭합니다. Instances 탭에서 Create ClusterCSIDriver를 클릭합니다.
다음 YAML 파일을 사용합니다.
apiVersion: operator.openshift.io/v1 kind: ClusterCSIDriver metadata: name: filestore.csi.storage.gke.io spec: managementState: Managed
- 생성을 클릭합니다.
다음 조건이 "true" 상태로 변경될 때까지 기다립니다.
- GCPFilestoreDriverCredentialsRequestControllerAvailable
- GCPFilestoreDriverNodeServiceControllerAvailable
- GCPFilestoreDriverControllerServiceControllerAvailable
-
관리
5.16.4. GCP Filestore 스토리지의 스토리지 클래스 생성
Operator를 설치한 후 GCP(Google Compute Platform) Filestore 볼륨의 동적 프로비저닝을 위한 스토리지 클래스를 생성해야 합니다.
사전 요구 사항
- 실행 중인 OpenShift Container Platform 클러스터에 로그인되어 있습니다.
절차
스토리지 클래스를 생성하려면 다음을 수행합니다.
다음 예제 YAML 파일을 사용하여 스토리지 클래스를 생성합니다.
YAML 파일의 예
kind: StorageClass apiVersion: storage.k8s.io/v1 metadata: name: filestore-csi provisioner: filestore.csi.storage.gke.io parameters: network: network-name 1 allowVolumeExpansion: true volumeBindingMode: WaitForFirstConsumer
- 1
- Filestore 인스턴스를 생성해야 하는 GCP 가상 프라이빗 클라우드(VPC) 네트워크의 이름을 지정합니다.
Filestore 인스턴스를 생성해야 하는 VPC 네트워크의 이름을 지정합니다.
Filestore 인스턴스를 생성할 VPC 네트워크를 지정하는 것이 좋습니다. VPC 네트워크가 지정되지 않은 경우 CSI(Container Storage Interface) 드라이버는 프로젝트의 기본 VPC 네트워크에 인스턴스를 생성하려고 합니다. IPI 설치 시 VPC 네트워크 이름은 일반적으로 접미사 "-network"가 있는 클러스터 이름입니다. 그러나 UPI 설치 시 VPC 네트워크 이름은 사용자가 선택한 모든 값일 수 있습니다.
다음 명령을 사용하여
MachineSets
오브젝트를 검사하여 VPC 네트워크 이름을 확인할 수 있습니다.$ oc -n openshift-machine-api get machinesets -o yaml | grep "network:" - network: gcp-filestore-network (...)
이 예제에서 이 클러스터의 VPC 네트워크 이름은 "gcp-filestore-network"입니다.
5.16.5. 클러스터 및 GCP 파일 저장소 삭제
일반적으로 클러스터를 삭제하면 OpenShift Container Platform 설치 프로그램이 클러스터에 속하는 모든 클라우드 리소스를 삭제합니다. 그러나 클러스터가 삭제되면 GCP(Google Compute Platform) Filestore 인스턴스가 자동으로 삭제되지 않으므로 클러스터를 제거하기 전에 Filestore 스토리지 클래스를 사용하는 모든 PVC(영구 볼륨 클레임)를 수동으로 삭제해야 합니다.
절차
모든 GCP Filestore PVC를 삭제하려면 다음을 수행합니다.
스토리지 클래스
filestore-csi
를 사용하여 생성된 모든 PVC를 나열합니다.$ oc get pvc -o json -A | jq -r '.items[] | select(.spec.storageClassName == "filestore-csi")
이전 명령으로 나열된 모든 PVC를 삭제합니다.
$ oc delete <pvc-name> 1
- 1
- <pvc-name>을 삭제해야 하는 모든 PVC의 이름으로 변경합니다.