Categorygithub.com/c3mb0/kuberesolver
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

# Constants

No description provided by the author
No description provided by the author
No description provided by the author
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