Aggregation
API Aggregation enables the amplification of Kubernetes API without altering its core code. What this means is that third-party services can be registered into Kubernetes API, which consequently allows for the access of these external services right within Kubernetes API.
Note: Another method for expanding the horizons of Kubernetes API is via CustomResourceDefinition (CRD).
Picking the Right Times for Aggregation
If your API is Declarative.
If your API doesn't quite cut the Declarative model.
If you'd want your new types to be read and altered with kubectl
.
kubectl
support: Check Not required
box
Want to view your brand new types in a Kubernetes UI like the dashboard along with other built-in types?
Spare the thought if Kubernetes UI support isn't required.
If you're building a new API from scratch.
If you're already equipped with a functioning program serving your API efficiently.
If you are open to embracing the format restriction imposed on REST resource paths by Kubernetes, such as API Groups and Namespaces. (Dive deeper into the API Overview.)
If you need specific REST paths to gel with an existing REST API.
If your resources seamlessly fit into a cluster or namespaces of a cluster.
If cluster or namespace scoped resources are bad fits; instead, you require control over resource path specifics.
If you wish to tap into Kubernetes API support features.
If those features aren't on your required list.
Jumpstarting API Aggregation
Augment kube-apiserver by tweaking the configuration:
If kube-proxy
is a no-show on the Master, then this configuration is mandatory:
Building the Extended API
Ensure the APIService API is on-board (usually, it is! Verify with
kubectl get apiservice
command)Set up RBAC rules
Create a namespace to host your extended API service
Generate CA and certificates, vital for https
Create a 'secret' safehouse for storing certificates
Launch a deployment to serve your extended API service and configure the certificates using the previously generated 'secret', enabling https services
Create a ClusterRole and ClusterRoleBinding
Create a non-namespace apiservice; remember to set
spec.caBundle
Rollout
kubectl get <resource-name>
; if everything's ticking right, it should returnNo resources found.
Use the apiserver-builder tool for a smooth run through the above steps.
Examples To Check Out
Visit sample-apiserver and apiserver-builder/example.
最后更新于