Kubernetes에서 서비스 변경 사항을 모니터링하는 것은 애플리케이션 상태를 유지하는 데 중요합니다. 이 문서에서는 client-go 라이브러리를 사용하여 Kubernetes 서비스에 대한 이벤트 감시를 구현하는 방법을 보여줍니다.
시작하려면 clientcmd.BuildConfigFromFlags()를 사용하여 구성 개체를 생성하여 Kubernetes 구성을 설정하세요.
import ( "k8s.io/client-go/tools/clientcmd" ) // ... config, err := clientcmd.BuildConfigFromFlags("", *kubeconfig) if err != nil { panic(err.Error()) }
구성을 사용하여 새 Kubernetes 클라이언트를 생성합니다.
import ( "k8s.io/client-go/kubernetes" ) // ... clientset, err := kubernetes.NewForConfig(config)
원하는 서비스를 나타내는 관심 목록을 생성합니다. 모니터:
import ( "k8s.io/client-go/tools/cache" v1 "k8s.io/client-go/pkg/api/v1" ) // ... watchlist := cache.NewListWatchFromClient(clientset.Core().RESTClient(), "services", v1.NamespaceDefault, fields.Everything())
수신 이벤트를 처리하기 위한 정보 제공자 설정:
informer := cache.NewInformer( watchlist, &v1.Service{}, time.Second * 0, cache.ResourceEventHandlerFuncs{ AddFunc: func(obj interface{}) { fmt.Printf("service added: %s \n", obj) }, DeleteFunc: func(obj interface{}) { fmt.Printf("service deleted: %s \n", obj) }, UpdateFunc: func(oldObj, newObj interface{}) { fmt.Printf("service changed \n") }, }, )
정보 제공자를 실행하여 이벤트 모니터링 시작:
stop := make(chan struct{}) go informer.Run(stop)
프로그램 실행 유지 서비스 이벤트를 무기한 모니터링합니다:
for { time.Sleep(time.Second) }
위 내용은 Go Client-go를 사용하여 Kubernetes 서비스 이벤트를 시청하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!