You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
apiserver-builder-alpha implements libraries and tools to quickly and easily build Kubernetes apiservers/controllers to support custom resource types based on APIServer Aggregation
Unless you absolutely need apiserver-aggregation, you are recommended to use Kubebuilder instead of apiserver-builder for
building Kubernetes APIs. Kubebuilder builds APIs using CRDs and addresses limitations and feedback from
apiserver-builder.
Apiserver Builder is a collection of libraries and tools to build native
Kubernetes extensions using Kubernetes apiserver aggregation. Aggregated
apiserver empowers you to customize your apiserver to do following things
cannot achieved by CR[D]:
Makes your apiserver adopt different storage APIs rather than ETCDv3
Extends long-running subresources/endpoints like websocket for your own resources
Integrates your apiserver with whatever other external systems
Installation
go install sigs.k8s.io/apiserver-builder-alpha/cmd/apiserver-boot@v1.23.0
Addon apiservers are a Kubernetes extension point allowing fully featured Kubernetes
APIs to be developed on the same api-machinery used to build the core Kubernetes APIS,
but with the flexibility of being distributed and installed separately from
the Kubernetes project. This allows APIs to be developed outside of the
Kubernetes repo and installed separately as a package.
Building addon apiservers directly on the raw api-machinery libraries requires non-trivial
code that must be maintained and rebased as the raw libraries change. The goal of this project is
to make building apiservers in Go simple and accessible to everyone in the
Kubernetes community.
apiserver-builder provides libraries, code generators, and tooling to make it possible to build
and run a basic apiserver in an afternoon, while providing all of the hooks to offer the
same capabilities when building from scratch.
Highlights
Tools to bootstrap type definitions, controllers (powered by controller-runtime framework), tests and documentation for new resources
Tools to build and run the extension control plane standalone and in minikube and remote clusters.
Easily watch and update Kubernetes API types from your controller
Easily add new resources and subresources
Provides sane defaults for most values, but can be overridden
KineExample: Plumbs aggregated apiserver over SQL-storages including sqlite, mysql, etc..
PodLogsExample: Serves pod/logs in aggregation layer to offload kube-apiserver connections.
PodExecExample: Serves pod/exec in aggregation layer to offload kube-apiserver connections.
Guides
Note: The guides are presented roughly in the order of recommended progression.
Building APIs concept guide
Conceptual information on how APIs and the Kubernetes control plane is structure and how to
build new API extensions using apiserver-builder.
If you want to get straight to building something without knowing all the details of what is going on,
skip ahead to the tools guide and come back to this later.
apiserver-builder-alpha implements libraries and tools to quickly and easily build Kubernetes apiservers/controllers to support custom resource types based on APIServer Aggregation