Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/flant/addon-operator
A system to manage additional components for Kubernetes cluster in a simple, consistent and automated way.
https://github.com/flant/addon-operator
devops kubernetes kubernetes-addons kubernetes-operators
Last synced: 2 days ago
JSON representation
A system to manage additional components for Kubernetes cluster in a simple, consistent and automated way.
- Host: GitHub
- URL: https://github.com/flant/addon-operator
- Owner: flant
- License: apache-2.0
- Created: 2019-03-04T14:18:23.000Z (almost 6 years ago)
- Default Branch: main
- Last Pushed: 2024-07-11T11:24:25.000Z (6 months ago)
- Last Synced: 2024-07-11T22:46:33.921Z (6 months ago)
- Topics: devops, kubernetes, kubernetes-addons, kubernetes-operators
- Language: Go
- Homepage: https://flant.github.io/addon-operator/
- Size: 12.2 MB
- Stars: 474
- Watchers: 17
- Forks: 27
- Open Issues: 42
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-repositories - flant/addon-operator - A system to manage additional components for Kubernetes cluster in a simple, consistent and automated way. (Go)
README
**Addon-operator** combines Helm charts with hooks and values storage to transform charts into smart modules that configure themselves and respond to changes in the cluster. It is a sister project for [shell-operator](https://github.com/flant/shell-operator) and is actively used in [Deckhouse Kubernetes Platform](https://github.com/deckhouse/deckhouse) to implement its modules.
# Features
- **Discovery of values** for Helm charts — parameters can be generated, calculated or retrieved from the cluster;
- **Continuous discovery** — parameters can be changed in response to cluster events;
- **Controlled Helm execution** — addon-operator monitors the Helm operation to ensure the Helm chart’s successful installation. Coming soon: use kubedog to track deploy status and more;
- **Custom extra actions before and after running Helm** as well as any other events via the hooks paradigm. See related [shell-operator capabilities](https://github.com/flant/shell-operator/blob/master/HOOKS.md).Additionally, addon-operator provides:
- ease of maintenance of Kubernetes clusters: use the tools that Ops are familiar with to build your modules and hooks such as Bash, kubectl, Python, etc;
- the execution queue of modules and hooks that ensures the launch sequence and repeated execution in case of an error, which *simplifies programming of modules* and ensures *predictable outcome* of their operation;
- the possibility of *dynamic enabling/disabling* of a module (depending on detected parameters);
- the ability to tie *conditions of module activation* to the activation of other modules;
- *the unified ConfigMap* for the configuration of all settings;
- the ability to run Helm only if parameters have changed. In this case, `helm history` would output only releases with changes;
- *global hooks* for figuring out parameters and performing actions that affect several dependent modules;
- off-the-shelf *metrics* for monitoring via Prometheus.# Documentation
Please see the [docs](https://flant.github.io/addon-operator/) for more in-depth information and supported features.
# Installation
You may use a prepared image [flant/addon-operator](https://hub.docker.com/r/flant/addon-operator) to install addon-operator in a cluster. The image comprises a binary `addon-operator` file as well as several required tools: `helm`, `kubectl`, `jq`, `bash`.
The installation incorporates the image building process with *files of modules and hooks*, applying the necessary RBAC rights and deploying the image in the cluster.
## Examples
To experiment with modules, hooks, and values we've prepared some [examples](/examples).
[Deckhouse Kubernetes Platform](https://deckhouse.io/) was an initial reason to create addon-operator, thus [its modules](https://github.com/deckhouse/deckhouse/tree/main/modules) might become a vital source of inspiration for implementing your own modules.
Sharing your examples of using addon-operator is much appreciated. Please, use the [relevant Discussions section](https://github.com/flant/addon-operator/discussions/categories/show-and-tell) for that.
# What's next?
Explore [shell-operator](https://github.com/flant/shell-operator) documentation, especially its [hooks](https://github.com/flant/shell-operator/blob/main/docs/src/HOOKS.md) section.
# Community
Please feel free to reach developers/maintainers and users via [GitHub Discussions](https://github.com/flant/addon-operator/discussions) for any questions regarding addon-operator.
You're also welcome to follow [@flant_com](https://twitter.com/flant_com) to stay informed about all our Open Source initiatives.
# License
Apache License 2.0, see [LICENSE](LICENSE).