mirror of
https://github.com/kubernetes/client-go.git
synced 2025-05-03 05:36:20 +00:00
The azure and gcp plugins no longer do anything other than point to the corresponding external credential plugins. Client code should no longer try to load them, so they should be removed from the examples. Signed-off-by: Stephen Kitt <skitt@redhat.com> Kubernetes-commit: 4531c6de760ec42941d9f509103f1b29c88bfae0
74 lines
2.2 KiB
Go
74 lines
2.2 KiB
Go
/*
|
|
Copyright 2016 The Kubernetes Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
// Note: the example only works with the code within the same release/branch.
|
|
package main
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"time"
|
|
|
|
"k8s.io/apimachinery/pkg/api/errors"
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
"k8s.io/client-go/kubernetes"
|
|
"k8s.io/client-go/rest"
|
|
//
|
|
// Uncomment to load all auth plugins
|
|
// _ "k8s.io/client-go/plugin/pkg/client/auth"
|
|
//
|
|
// Or uncomment to load specific auth plugins
|
|
// _ "k8s.io/client-go/plugin/pkg/client/auth/oidc"
|
|
)
|
|
|
|
func main() {
|
|
// creates the in-cluster config
|
|
config, err := rest.InClusterConfig()
|
|
if err != nil {
|
|
panic(err.Error())
|
|
}
|
|
// creates the clientset
|
|
clientset, err := kubernetes.NewForConfig(config)
|
|
if err != nil {
|
|
panic(err.Error())
|
|
}
|
|
for {
|
|
// get pods in all the namespaces by omitting namespace
|
|
// Or specify namespace to get pods in particular namespace
|
|
pods, err := clientset.CoreV1().Pods("").List(context.TODO(), metav1.ListOptions{})
|
|
if err != nil {
|
|
panic(err.Error())
|
|
}
|
|
fmt.Printf("There are %d pods in the cluster\n", len(pods.Items))
|
|
|
|
// Examples for error handling:
|
|
// - Use helper functions e.g. errors.IsNotFound()
|
|
// - And/or cast to StatusError and use its properties like e.g. ErrStatus.Message
|
|
_, err = clientset.CoreV1().Pods("default").Get(context.TODO(), "example-xxxxx", metav1.GetOptions{})
|
|
if errors.IsNotFound(err) {
|
|
fmt.Printf("Pod example-xxxxx not found in default namespace\n")
|
|
} else if statusError, isStatus := err.(*errors.StatusError); isStatus {
|
|
fmt.Printf("Error getting pod %v\n", statusError.ErrStatus.Message)
|
|
} else if err != nil {
|
|
panic(err.Error())
|
|
} else {
|
|
fmt.Printf("Found example-xxxxx pod in default namespace\n")
|
|
}
|
|
|
|
time.Sleep(10 * time.Second)
|
|
}
|
|
}
|