1
0
Fork 0
mirror of https://github.com/kyverno/kyverno.git synced 2025-01-20 18:52:16 +00:00

Added kubeconfig flag support (#4308)

* Added kubeconfig flag support

Signed-off-by: Ayushman Mishra <ayushvidushi01@gmail.com>

* removed swp file

Signed-off-by: Ayushman Mishra <ayushvidushi01@gmail.com>

* changed

Signed-off-by: Ayushman Mishra <ayushvidushi01@gmail.com>

Signed-off-by: Ayushman Mishra <ayushvidushi01@gmail.com>
Co-authored-by: shuting <shuting@nirmata.com>
This commit is contained in:
Ayushman 2022-08-29 11:51:42 +05:30 committed by GitHub
parent 8e65e558e4
commit 1394b91898
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 68 additions and 27 deletions

View file

@ -27,13 +27,13 @@ import (
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/labels" "k8s.io/apimachinery/pkg/labels"
"k8s.io/client-go/kubernetes" "k8s.io/client-go/kubernetes"
"k8s.io/client-go/rest"
"k8s.io/klog/v2" "k8s.io/klog/v2"
"k8s.io/klog/v2/klogr" "k8s.io/klog/v2/klogr"
"sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/log"
) )
var ( var (
kubeconfig string
setupLog = log.Log.WithName("setup") setupLog = log.Log.WithName("setup")
clientRateLimitQPS float64 clientRateLimitQPS float64
clientRateLimitBurst int clientRateLimitBurst int
@ -65,6 +65,7 @@ func main() {
klog.InitFlags(nil) // add the block above before invoking klog.InitFlags() klog.InitFlags(nil) // add the block above before invoking klog.InitFlags()
log.SetLogger(klogr.New()) log.SetLogger(klogr.New())
flag.StringVar(&kubeconfig, "kubeconfig", "", "Path to a kubeconfig. Only required if out-of-cluster.")
flag.Float64Var(&clientRateLimitQPS, "clientRateLimitQPS", 0, "Configure the maximum QPS to the Kubernetes API server from Kyverno. Uses the client default if zero.") flag.Float64Var(&clientRateLimitQPS, "clientRateLimitQPS", 0, "Configure the maximum QPS to the Kubernetes API server from Kyverno. Uses the client default if zero.")
flag.IntVar(&clientRateLimitBurst, "clientRateLimitBurst", 0, "Configure the maximum burst for throttle. Uses the client default if zero.") flag.IntVar(&clientRateLimitBurst, "clientRateLimitBurst", 0, "Configure the maximum burst for throttle. Uses the client default if zero.")
if err := flag.Set("v", "2"); err != nil { if err := flag.Set("v", "2"); err != nil {
@ -76,13 +77,9 @@ func main() {
// os signal handler // os signal handler
stopCh := signal.SetupSignalHandler() stopCh := signal.SetupSignalHandler()
// create client config // create client config
clientConfig, err := rest.InClusterConfig() clientConfig, err := config.CreateClientConfig(kubeconfig, clientRateLimitQPS, clientRateLimitBurst)
if err != nil { if err != nil {
setupLog.Error(err, "Failed to create clientConfig") setupLog.Error(err, "Failed to build kubeconfig")
os.Exit(1)
}
if err := config.ConfigureClientConfig(clientConfig, clientRateLimitQPS, clientRateLimitBurst); err != nil {
setupLog.Error(err, "Failed to create clientConfig")
os.Exit(1) os.Exit(1)
} }

View file

@ -44,7 +44,6 @@ import (
_ "go.uber.org/automaxprocs" // #nosec _ "go.uber.org/automaxprocs" // #nosec
kubeinformers "k8s.io/client-go/informers" kubeinformers "k8s.io/client-go/informers"
"k8s.io/client-go/kubernetes" "k8s.io/client-go/kubernetes"
"k8s.io/client-go/rest"
"k8s.io/client-go/tools/cache" "k8s.io/client-go/tools/cache"
"k8s.io/klog/v2" "k8s.io/klog/v2"
"k8s.io/klog/v2/klogr" "k8s.io/klog/v2/klogr"
@ -56,6 +55,7 @@ const resyncPeriod = 15 * time.Minute
var ( var (
// TODO: this has been added to backward support command line arguments // TODO: this has been added to backward support command line arguments
// will be removed in future and the configuration will be set only via configmaps // will be removed in future and the configuration will be set only via configmaps
kubeconfig string
serverIP string serverIP string
profilePort string profilePort string
metricsPort string metricsPort string
@ -91,6 +91,7 @@ func main() {
flag.IntVar(&webhookTimeout, "webhookTimeout", int(webhookconfig.DefaultWebhookTimeout), "Timeout for webhook configurations.") flag.IntVar(&webhookTimeout, "webhookTimeout", int(webhookconfig.DefaultWebhookTimeout), "Timeout for webhook configurations.")
flag.IntVar(&genWorkers, "genWorkers", 10, "Workers for generate controller.") flag.IntVar(&genWorkers, "genWorkers", 10, "Workers for generate controller.")
flag.IntVar(&maxQueuedEvents, "maxQueuedEvents", 1000, "Maximum events to be queued.") flag.IntVar(&maxQueuedEvents, "maxQueuedEvents", 1000, "Maximum events to be queued.")
flag.StringVar(&kubeconfig, "kubeconfig", "", "Path to a kubeconfig. Only required if out-of-cluster.")
flag.StringVar(&serverIP, "serverIP", "", "IP address where Kyverno controller runs. Only required if out-of-cluster.") flag.StringVar(&serverIP, "serverIP", "", "IP address where Kyverno controller runs. Only required if out-of-cluster.")
flag.BoolVar(&profile, "profile", false, "Set this flag to 'true', to enable profiling.") flag.BoolVar(&profile, "profile", false, "Set this flag to 'true', to enable profiling.")
flag.StringVar(&profilePort, "profilePort", "6060", "Enable profiling at given port, defaults to 6060.") flag.StringVar(&profilePort, "profilePort", "6060", "Enable profiling at given port, defaults to 6060.")
@ -124,13 +125,9 @@ func main() {
debug := serverIP != "" debug := serverIP != ""
// clients // clients
clientConfig, err := rest.InClusterConfig() clientConfig, err := config.CreateClientConfig(kubeconfig, clientRateLimitQPS, clientRateLimitBurst)
if err != nil { if err != nil {
setupLog.Error(err, "Failed to create clientConfig") setupLog.Error(err, "Failed to build kubeconfig")
os.Exit(1)
}
if err := config.ConfigureClientConfig(clientConfig, clientRateLimitQPS, clientRateLimitBurst); err != nil {
setupLog.Error(err, "Failed to create clientConfig")
os.Exit(1) os.Exit(1)
} }
kyvernoClient, err := kyvernoclient.NewForConfig(clientConfig) kyvernoClient, err := kyvernoclient.NewForConfig(clientConfig)

View file

@ -5,14 +5,30 @@ import (
"math" "math"
rest "k8s.io/client-go/rest" rest "k8s.io/client-go/rest"
clientcmd "k8s.io/client-go/tools/clientcmd"
) )
// ConfigureClientConfig creates client config and applies rate limit QPS and burst // CreateClientConfig creates client config and applies rate limit QPS and burst
func ConfigureClientConfig(clientConfig *rest.Config, qps float64, burst int) error { func CreateClientConfig(kubeconfig string, qps float64, burst int) (*rest.Config, error) {
clientConfig, err := createClientConfig(kubeconfig)
if err != nil {
return nil, err
}
if qps > math.MaxFloat32 { if qps > math.MaxFloat32 {
return fmt.Errorf("client rate limit QPS must not be higher than %e", math.MaxFloat32) return nil, fmt.Errorf("client rate limit QPS must not be higher than %e", math.MaxFloat32)
} }
clientConfig.Burst = burst clientConfig.Burst = burst
clientConfig.QPS = float32(qps) clientConfig.QPS = float32(qps)
return nil return clientConfig, nil
}
// createClientConfig creates client config
func createClientConfig(kubeconfig string) (*rest.Config, error) {
if kubeconfig == "" {
logger.Info("Using in-cluster configuration")
return rest.InClusterConfig()
}
logger.V(4).Info("Using specified kubeconfig", "kubeconfig", kubeconfig)
return clientcmd.BuildConfigFromFlags("", kubeconfig)
} }

View file

@ -2,17 +2,20 @@ package config_test
import ( import (
"math" "math"
"os"
"testing" "testing"
"gotest.tools/assert"
"k8s.io/client-go/rest"
"github.com/kyverno/kyverno/pkg/config" "github.com/kyverno/kyverno/pkg/config"
"gotest.tools/assert"
"k8s.io/apimachinery/pkg/runtime"
clientcmdapi "k8s.io/client-go/tools/clientcmd/api"
clientcmdlatest "k8s.io/client-go/tools/clientcmd/api/latest"
) )
func Test_CreateClientConfig_WithKubeConfig(t *testing.T) { func Test_CreateClientConfig_WithKubeConfig(t *testing.T) {
c := &rest.Config{} cf := createMinimalKubeconfig(t)
err := config.ConfigureClientConfig(c, 0, 0) defer os.Remove(cf)
_, err := config.CreateClientConfig(cf, 0, 0)
assert.NilError(t, err) assert.NilError(t, err)
} }
@ -21,8 +24,9 @@ func Test_CreateClientConfig_SetBurstQPS(t *testing.T) {
qps = 55 qps = 55
burst = 99 burst = 99
) )
c := &rest.Config{} cf := createMinimalKubeconfig(t)
err := config.ConfigureClientConfig(c, qps, burst) defer os.Remove(cf)
c, err := config.CreateClientConfig(cf, qps, burst)
assert.NilError(t, err) assert.NilError(t, err)
assert.Equal(t, float32(qps), c.QPS) assert.Equal(t, float32(qps), c.QPS)
assert.Equal(t, burst, c.Burst) assert.Equal(t, burst, c.Burst)
@ -30,7 +34,34 @@ func Test_CreateClientConfig_SetBurstQPS(t *testing.T) {
func Test_CreateClientConfig_LimitQPStoFloat32(t *testing.T) { func Test_CreateClientConfig_LimitQPStoFloat32(t *testing.T) {
qps := float64(math.MaxFloat32) * 2 qps := float64(math.MaxFloat32) * 2
c := &rest.Config{} cf := createMinimalKubeconfig(t)
err := config.ConfigureClientConfig(c, qps, 0) defer os.Remove(cf)
_, err := config.CreateClientConfig(cf, qps, 0)
assert.ErrorContains(t, err, "QPS") assert.ErrorContains(t, err, "QPS")
} }
func createMinimalKubeconfig(t *testing.T) string {
t.Helper()
minimalConfig := clientcmdapi.Config{
Clusters: map[string]*clientcmdapi.Cluster{
"test": {Server: "http://localhost:7777"},
},
AuthInfos: map[string]*clientcmdapi.AuthInfo{
"test": {},
},
Contexts: map[string]*clientcmdapi.Context{
"test": {AuthInfo: "test", Cluster: "test"},
},
CurrentContext: "test",
}
f, err := os.CreateTemp("", "")
assert.NilError(t, err)
enc, err := runtime.Encode(clientcmdlatest.Codec, &minimalConfig)
assert.NilError(t, err)
_, err = f.Write(enc)
assert.NilError(t, err)
assert.NilError(t, f.Close())
return f.Name()
}