5.15. Google Compute Platform Filestore CSI Driver Operator
5.15.1. 개요
OpenShift Container Platform은 GCP(Google Compute Platform) 파일 저장소 스토리지용 CSI(Container Storage Interface) 드라이버를 사용하여 PV(영구 볼륨)를 프로비저닝할 수 있습니다.
CSI Operator 및 드라이버를 사용할 때는 영구 스토리지 및 CSI 볼륨 구성에 대해 숙지하는 것이 좋습니다.
GCP Filestore 스토리지 자산에 마운트되는 CSI 프로비저닝 PV를 생성하려면 openshift-cluster-csi-drivers
네임스페이스에 GCP Filestore CSI 드라이버와 GCP Filestore CSI 드라이버를 설치합니다.
- GCP Filestore CSI Driver Operator 는 기본적으로 스토리지 클래스를 제공하지 않지만 필요한 경우 스토리지 클래스를 생성할 수 있습니다. GCP Filestore CSI Driver Operator는 필요에 따라 스토리지 볼륨을 생성할 수 있으므로 클러스터 관리자가 스토리지를 사전 프로비저닝할 필요가 없어 동적 볼륨 프로비저닝을 지원합니다.
- GCP Filestore CSI 드라이버 를 사용하면 GCP Filestore PV를 생성하고 마운트할 수 있습니다.
5.15.2. CSI 정보
스토리지 벤더는 일반적으로 Kubernetes의 일부로 스토리지 드라이버를 제공합니다. CSI(Container Storage Interface) 구현을 통해 타사 공급자는 코어 Kubernetes 코드를 변경하지 않고도 표준 인터페이스를 사용하여 스토리지 플러그인을 제공할 수 있습니다.
CSI Operator는 in-tree 볼륨 플러그인에서 사용할 수 없는 볼륨 스냅샷과 같은 OpenShift Container Platform 사용자 스토리지 옵션을 제공합니다.
5.15.3. GCP Filestore CSI Driver Operator 설치
GCP(Google Compute Platform) Filestore CSI(Container Storage Interface) 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
<my_gce_project>
를 Google Cloud 프로젝트로 바꿉니다.
Google Cloud 웹 콘솔을 사용하여 이 작업을 수행할 수도 있습니다.
GCP Filestore CSI Operator를 설치합니다.
-
Operators
OperatorHub를 클릭합니다. - 필터 상자에 GCP Filestore를 입력하여 GCP Filestore CSI Operator를 찾습니다.
- GCP Filestore CSI Driver Operator 버튼을 클릭합니다.
- GCP Filestore CSI Driver Operator 페이지에서 설치를 클릭합니다.
Operator 설치 페이지에서 다음을 확인합니다.
- 클러스터의 모든 네임스페이스(기본값)가 선택됩니다.
- 설치된 네임스페이스는 openshift-cluster-csi-drivers로 설정됩니다.
설치를 클릭합니다.
설치가 완료되면 GCP Filestore CSI Operator가 웹 콘솔의 설치된 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.15.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: connect-mode: DIRECT_PEERING 1 network: network-name 2 allowVolumeExpansion: true volumeBindingMode: WaitForFirstConsumer
Filestore 인스턴스를 생성해야 하는 VPC 네트워크의 이름을 지정합니다.
Filestore 인스턴스를 생성해야 하는 VPC 네트워크를 지정하는 것이 좋습니다. VPC 네트워크가 지정되지 않은 경우 CSI(Container Storage Interface) 드라이버는 프로젝트의 기본 VPC 네트워크에 인스턴스를 생성하려고 합니다.
IPI 설치 시 VPC 네트워크 이름은 일반적으로 접미사 "-network"가 있는 클러스터 이름입니다. 그러나 UPI 설치 시 VPC 네트워크 이름은 사용자가 선택한 모든 값이 될 수 있습니다.
공유 VPC(
connect-mode
=PRIVATE_SERVICE_ACCESS
)의 경우 네트워크가 전체 VPC 이름이어야 합니다. 예:projects/shared-vpc-name/global/networks/gcp-filestore-network
.다음 명령을 사용하여
MachineSets
오브젝트를 검사하여 VPC 네트워크 이름을 확인할 수 있습니다.$ oc -n openshift-machine-api get machinesets -o yaml | grep "network:" - network: gcp-filestore-network (...)
이 예에서 이 클러스터의 VPC 네트워크 이름은 "gcp-filestore-network"입니다.
5.15.5. 클러스터 및 GCP 파일 저장소 삭제
일반적으로 클러스터를 삭제하면 OpenShift Container Platform 설치 프로그램이 해당 클러스터에 속하는 모든 클라우드 리소스를 삭제합니다. 그러나 GCP(Google Compute Platform) Filestore 리소스의 특수 특성으로 인해 자동화된 정리 프로세스가 드문 경우 모두 제거되지 않을 수 있습니다.
따라서 제거 프로세스에서 모든 클러스터 소유 Filestore 리소스가 삭제되었는지 확인하는 것이 좋습니다.
프로세스
모든 GCP Filestore PVC가 삭제되었는지 확인하려면 다음을 수행하십시오.
- GUI 또는 CLI를 사용하여 Google Cloud 계정에 액세스합니다.
kubernetes-io-cluster-${CLUSTER_ID}=owned
라벨을 사용하여 모든 리소스를 검색합니다.클러스터 ID는 삭제된 클러스터에 고유하므로 해당 클러스터 ID가 있는 나머지 리소스가 없어야 합니다.
- 예기치 않은 경우 나머지 리소스가 있으며 삭제합니다.