Iter8 is the Kubernetes release optimizer built for DevOps, MLOps, SRE and data science teams. Iter8 makes it easy to ensure that Kubernetes apps and ML models perform well and maximize business value.
Iter8 supports the following use-cases.
- Performance testing and SLO validation of HTTP services.
- Performance testing and SLO validation of gRPC services.
- SLO validation using custom metrics from any database(s) or REST API(s).
Iter8 introduces the notion of an experiment, which is a list of configurable tasks that are executed in a specific sequence.
Iter8 packs a number of powerful features that facilitate Kubernetes app testing and experimentation. They include the following.
- Generating load and collecting built-in metrics for HTTP and gRPC services. Simplifies performance testing by eliminating the need to setup and use metrics databases.
- Well-defined notion of service-level objectives (SLOs). Makes it simple to define and verify SLOs in experiments.
- Custom metrics. Enables the use of custom metrics from any database(s) or REST API(s) in experiments.
- Readiness check. The performance testing portion of the experiment begins only after the service is ready.
- HTML/text reports. Promotes human understanding of experiment results through visual insights.
- Assertions. Verifies whether the target app satisfies the specified SLOs or not after an experiment. Simplifies automation in CI/CD/GitOps pipelines: branch off into different paths depending upon whether the assertions are true or false.
- Multi-loop experiments. Experiment tasks can be executed periodically (multi-loop) instead of just once (single-loop). This enables Iter8 to refresh metric values and perform SLO validation using the latest metric values during each loop.
- Experiment anywhere. Iter8 experiments can be launched inside a Kubernetes cluster, in local environments, or inside a GitHub Actions pipeline.
Please see https://iter8.tools for the complete documentation.
Iter8 issues are tracked here.
We welcome PRs!
See here for information about ways to contribute, Iter8 community meetings, finding an issue, asking for help, pull-request lifecycle, and more.
Iter8 is primarily written in Go
and builds on a few awesome open source projects including: