Client-Go로 CustomResourceDefinitions(CRD) 보기
CustomResourceDefinitions(CRD)는 Kubernetes의 핵심 API를 확장하여 사용자가 자신의 리소스 유형. CRD의 변경 사항을 감시하려면 Kubernetes 클라이언트 라이브러리인 client-go를 활용할 수 있습니다.
표준 리소스용 Client-Go
Client-go는 간단한 메커니즘을 제공합니다. 서비스와 같은 표준 리소스의 변경 사항을 감시합니다. 다음 예에서는 신규 또는 수정된 서비스를 감시하는 방법을 보여줍니다.
<code class="go">import ( "k8s.io/api/core/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/client-go/kubernetes" "k8s.io/client-go/tools/clientcmd" ) func handleNewServices(clientset *kubernetes.Clientset) { for { serviceStreamWatcher, err := clientset.CoreV1().Services("").Watch(metav1.ListOptions{}) if err != nil { panic(err.Error()) } // Process events // ... } }</code>
CRD용 Client-Go 확장
Client-go는 기본적으로 CRD를 인식하지 않습니다. 이를 지원하려면 사용자 지정 리소스에 대한 클라이언트를 생성해야 합니다. Kubernetes는 이러한 목적을 위한 코드 생성 도구를 제공합니다.
예를 들어 제공된 스니펫에 정의된 ApiGateway CRD용 클라이언트를 생성하려면 [이 블로그 게시물](블로그 게시물 링크)에 설명된 단계를 따르세요.
코드 생성
클라이언트 생성: 다음 명령을 실행하여 your-group을 CRD 그룹으로 바꾸세요.
client-gen --input-base "" --input your-group/v1 --output-base ./pkg --output-package pkg/clientset/versioned --clientset-name versioned
그러면 pkg 디렉토리에 필요한 API와 클라이언트 구조체가 생성됩니다.
컨트롤러 예제
예제는 [이 샘플 컨트롤러](샘플 컨트롤러 링크)를 참조하세요. 생성된 클라이언트를 사용하여 CRD를 감시하는 방법에 대해 설명합니다. example_controller 패키지에는 감시 이벤트를 처리하는 코드가 포함되어 있습니다.
Kubebuilder
CRD용 클라이언트 구성 및 컨트롤러 생성 프로세스를 단순화하려면 [kubebuilder]( kubebuilder 링크). 이 도구는 위에 설명된 많은 단계를 자동화합니다.
위 내용은 Client-Go로 CRD(CustomResourceDefinitions)를 시청하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!