modulepackage
2.1.1+incompatible
Repository: https://github.com/c3mb0/kuberesolver.git
Documentation: pkg.go.dev
# README
kuberesolver
Grpc Client-Side Load Balancer with Kubernetes name resolver
// Register kuberesolver to grpc
kuberesolver.RegisterInCluster()
// is same as
resolver.Register(kuberesolver.NewBuilder(nil))
// you can bring your own k8s client, below is default behaviour
client, err := kuberesolver.NewInClusterK8sClient()
resolver.Register(kuberesolver.NewBuilder(client))
// USAGE:
// if schema is 'kubernetes' then grpc will use kuberesolver to resolve addresses
cc, err := grpc.Dial("kubernetes:///service-name.namespace:portname", opts...)
An url can be one of the following, grpc naming docs
kubernetes:///service-name:8080
kubernetes:///service-name:portname
kubernetes:///service-name.namespace:8080
kubernetes://namespace/service-name:8080
kubernetes://service-name:8080/
kubernetes://service-name.namespace:8080/
# Functions
NewBuilder creates a kubeBuilder which is used to factory Kuberesolvers.
NewInClusterK8sClient creates K8sClient if it is inside Kubernetes.
NewInsecureK8sClient creates an insecure k8s client which is suitable to connect kubernetes api behind proxy.
RegisterInCluster registers the kuberesolver builder to grpc.
No description provided by the author
# Structs
No description provided by the author
No description provided by the author
Event represents a single event to a watched resource.
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
# Interfaces
K8sClient is minimal kubernetes client interface.
# Type aliases
No description provided by the author