1 unstable release

0.1.0 Dec 10, 2023

#787 in Debugging

Download history 983/week @ 2024-07-27 1146/week @ 2024-08-03 698/week @ 2024-08-10 1092/week @ 2024-08-17 915/week @ 2024-08-24 1661/week @ 2024-08-31 1194/week @ 2024-09-07 733/week @ 2024-09-14 1418/week @ 2024-09-21 1249/week @ 2024-09-28 1555/week @ 2024-10-05 1500/week @ 2024-10-12 1133/week @ 2024-10-19 1144/week @ 2024-10-26 944/week @ 2024-11-02 1087/week @ 2024-11-09

4,524 downloads per month
Used in 2 crates

Apache-2.0

13KB
211 lines

kubert

Rust Kubernetes runtime helpers. Based on kube-rs.

kubert

Crates.io Documentation License

Features

  • clap command-line interface support;
  • A basic admin server with /ready and /live probe endpoints;
  • Optional prometheus-client integration;
  • A default Kubernetes client;
  • Graceful shutdown on SIGTERM or SIGINT signals;
  • An HTTPS server (for admission controllers and API extensions) with certificate reloading;
  • A utility for maintaining an index derived from watching one or more Kubernetes resources types;
  • A requeue channel that supports deferring/rescheduling updates (i.e. in case a write fails);
  • And a Runtime type that ties it all together!

Why not kube-rs?

The kube crate is great! And in fact, kubert builds on kube's client and runtime modules. This crate, however, captures some of the repeated patterns we've encountered building controllers for Linkerd. It doesn't try to hide kube--though it does reduce boilerplate around initializing watches and caches (reflectors); and it expects you to schedule work via the tokio runtime.

Examples

This repository includes a simple example application that demonstrates how to use a kubert::Runtime.

Other examples include:

kubert-prometheus-process

The kubert-prometheus-process crate provides process metrics for prometheus-client. It has no dependencies on kubert, and can be used independently.

Status

This crate is still fairly experimental, though it's based on production code from Linkerd; and we plan to use it in Linkerd moving forward.

Dependencies

~1.1–10MB
~115K SLoC