Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kubewharf/kubezoo
a lightweight kubernetes multi-tenancy gateway
https://github.com/kubewharf/kubezoo
kubernetes multi-tenancy serverless
Last synced: 22 days ago
JSON representation
a lightweight kubernetes multi-tenancy gateway
- Host: GitHub
- URL: https://github.com/kubewharf/kubezoo
- Owner: kubewharf
- License: apache-2.0
- Created: 2022-07-22T03:58:08.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-07-16T09:22:56.000Z (4 months ago)
- Last Synced: 2024-08-02T18:36:34.887Z (3 months ago)
- Topics: kubernetes, multi-tenancy, serverless
- Language: Go
- Homepage:
- Size: 1.53 MB
- Stars: 674
- Watchers: 21
- Forks: 57
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Governance: GOVERNANCE.md
- Roadmap: docs/roadmap.md
Awesome Lists containing this project
README
# KubeZoo - Gateway Service for Kubernetes
Multi-tenancyEnglish | [简体中文](./README.zh.md)
## Overview
KubeZoo is a lightweight gateway service that leverages the existing namespace model
and add multi-tenancy capability to existing Kubernetes. KubeZoo provides
view-level isolation among tenants by capturing and transforming the requests and responses.
Please refer to [design doc](./docs/design.md) for details.
## Why KubeZoo
There exists [three common multi-tenancy](https://kubernetes.io/blog/2021/04/15/three-tenancy-models-for-kubernetes/) models for Kubernetes,
i.e., Namespace as a Service (NaaS), Cluster as a Service (CaaS), Control Planes as a service (CPaaS). Each of them can be applied to address different
use cases. However, our cases have some specific requirements and constraints that can not be met by the existing models,
* ***Many Small Tenants*** - there usually exist hundreds of tenants who only need to run small batch workloads containing few pods for tens of minutes.
* ***Short Turnaround Time*** - users/tenants are usually impatient, who desire to have their service to be ready in minutes.
* ***Tight Manpower*** - managing thousands of clusters/control-planes can be labour-intensive and infeasible for medium-sized dev team.To address these cases, we present a new tenancy model, i.e., **Kubernetes API as a Service (KAaaS)**, which provides competent isolation with
negligible overheads and operation costs. KubeZoo implements this model with all tenants sharing both the control-plane and data-plane, which is
suitable for the scenarios where thousands of small tenants need to share an underlying Kubernetes cluster.
For more details lease refer [FAQ](./docs/faq.md).
## Prerequisites
Please check the [resource and system requirements](./docs/resource-and-system-requirements.md) before installing KubeZoo.
## Getting started
KubeZoo supports Kubernetes versions up to 1.24. Using higher Kubernetes versions may cause
compatibility issues. KubeZoo can be installed using any of the following methods:| Methods | Instruction | Estimated time |
| --------------------------- | ------------------------------------------ | -------------- |
| Deploy KubeZoo from scratch | [Deploy KubeZoo](./docs/manually-setup.md) | < 2 minutes |## Community
### Contributing
If you are willing to be a contributor for the KubeZoo project, please refer to our [CONTRIBUTING](CONTRIBUTING.md) document for details.
We have also prepared a developer [guide](./docs/developer-guide.md) to help the code contributors.### Contact
If you have any questions or want to contribute, you are welcome to communicate most things via GitHub issues or pull requests.
Or Contact to [Maintainers](./MAINTAINERS.md)## License
KubeZoo is under the Apache 2.0 license. See the [LICENSE](LICENSE) file for details.
Certain implementations in KubeZoo rely on the existing code from Kubernetes and the credits go to the original Kubernetes authors.