Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/giantswarm/operatorkit
An opinionated Go framework for developing Kubernetes operators
https://github.com/giantswarm/operatorkit
framework go kubernetes library operator
Last synced: 2 months ago
JSON representation
An opinionated Go framework for developing Kubernetes operators
- Host: GitHub
- URL: https://github.com/giantswarm/operatorkit
- Owner: giantswarm
- License: apache-2.0
- Archived: true
- Created: 2017-04-10T14:12:58.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2023-12-11T13:37:50.000Z (about 1 year ago)
- Last Synced: 2024-08-02T07:13:40.217Z (5 months ago)
- Topics: framework, go, kubernetes, library, operator
- Language: Go
- Homepage: https://godoc.org/github.com/giantswarm/operatorkit
- Size: 38 MB
- Stars: 197
- Watchers: 18
- Forks: 17
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Codeowners: CODEOWNERS
- Security: SECURITY.md
- Roadmap: ROADMAP.md
Awesome Lists containing this project
- awesome-kubernetes-operator-resources - Operatorkit - An opinionated Go framework for developing Kubernetes operators. (Operator Frameworks)
- awesome-repositories - giantswarm/operatorkit - An opinionated Go framework for developing Kubernetes operators (Go)
README
[![Go Reference](https://pkg.go.dev/badge/github.com/giantswarm/operatorkit.svg)](https://pkg.go.dev/github.com/giantswarm/operatorkit)
[![CircleCI](https://dl.circleci.com/status-badge/img/gh/giantswarm/operatorkit/tree/master.svg?style=svg)](https://dl.circleci.com/status-badge/redirect/gh/giantswarm/operatorkit/tree/master)# operatorkit
**:warning: Important: This library has been deprecated in favor of [kubebuilder](https://book.kubebuilder.io/). Please, use kubebuilder if you want to create a new operator.**
Package `operatorkit` implements an opinionated framework for developing
[Kubernetes operators]. It emerged as we extracted common functionality from a
number of the operators we developed at [Giant Swarm][giantswarm]. The goal of
this library is to provide a common structure for operator projects and to
encapsulate best practices we learned while running operators in production.## Features
- CRD primitives to reliably create, watch and delete custom resources, as well
as any Kubernetes runtime object.
- Managing [finalizers][finalizers] on reconciled objects, making sure the code
is executed at least once for each create/delete/update event.
- Guarantees to perform at least one successful deletion event reconciliation
to avoid unnecessary, possibly expensive interactions with third party
systems.
- Resource wrapping to gain ability of composing resources like middlewares.
- [Control Flow Primitives](docs/control_flow_primitives.md) that allow
cancellation and repetition of resource implementations.
- Independent packages. It is possible to use only certain parts of the library
without being bound to all primitives it provides.
- Ability to change behaviour that is often specific to an organization like
logging and error handling.
- [Pause Reconciliation](docs/pause_reconciliation.md) using pausing annotations
on runtime objects to stop and resume reconciliation on demand.## Roadmap
For future planned features and breaking changes see the [roadmap](ROADMAP.md).
## Docs
- [Control Flow Primitives](docs/control_flow_primitives.md)
- [File Structure](docs/file_structure.md)
- [Keeping Reconciliation Loops Short](docs/keeping_reconciliation_loops_short.md)
- [Managing CR Status Sub Resources](docs/managing_cr_status_sub_resources.md)
- [Metrics Provider](docs/metrics_provider.md)
- [Pause Reconciliation](docs/pause_reconciliation.md)
- [Troubleshooting](docs/troubleshooting.md)
- [Using Finalizers](docs/using_finalizers.md)
- [Using Kubernetes Events](docs/using_kubernetes_events.md)## Integration Tests
You can simply create a [`kind`](https://github.com/kubernetes-sigs/kind/)
cluster to run the integration tests.```nohighlight
kind create cluster
```The tests need to figure out how to connect to the Kubernetes cluster. Therefore
we need to set an environment variable pointing to your local kube config.```nohighlight
export E2E_KUBECONFIG=~/.kube/config
```Now you can easily run the integration tests.
```nohighlight
go test -v -tags=k8srequired ./integration/test/
```Once you did your testing you may want to delete your local test cluster again.
```nohighlight
kind delete cluster
```## Projects using operatorkit
[Giant Swarm operators] using `operatorkit`.
## Example
For a detailed state of art implementation, please see
[giantswarm/aws-operator](https://github.com/giantswarm/aws-operator).## Contributing & Reporting Bugs
See [CONTRIBUTING](CONTRIBUTING.md) for details on submitting patches, the
contribution workflow as well as reporting bugs.## License
`operatorkit` is under the Apache 2.0 license. See the [LICENSE](LICENSE) file
for details.[finalizers]: https://kubernetes.io/docs/tasks/access-kubernetes-api/extend-api-custom-resource-definitions/#finalizers
[giantswarm]: https://giantswarm.io
[Giant Swarm operators]: https://github.com/search?p=1&q=topic%3Aoperator+org%3Agiantswarm&type=Repositories
[Kubernetes operators]: https://coreos.com/operators