Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/apicurio/apicurio-registry-content-sync-operator

Provides synchronization with an Apicurio Registry, including monitoring for artifact CRDs to ensure they exist in the registry.
https://github.com/apicurio/apicurio-registry-content-sync-operator

Last synced: 2 months ago
JSON representation

Provides synchronization with an Apicurio Registry, including monitoring for artifact CRDs to ensure they exist in the registry.

Awesome Lists containing this project

README

        

## This repository is no longer maintained by the Apicurio Registry core maintainers.

There is a number of reasons for not following this approach, some of them being that this is a "broken by design" approach as the current Apicurio Registry API is not built to be idempotent and used in such a way:

Reconciliation is going to fail under some (common) conditions like concurrent updates of artifacts
Detecting failures in reconciliation requires extra monitoring and external tools causing Registry to misbehave instead of failing
Manually fixing a failure in reconciliation always requires human intervention
The amount of data that can be stored is limited (by default ETCD limit is, per object, 1.5MB)

# apicurio-registry-content-sync-operator

A Kubernetes Operator that allows to manage the lifecycle of Artifacts in [Apicurio Registry](https://www.apicur.io/registry/).
A perfect tool to manage your APIs and Schemas in Apicurio Registry using Git Ops processes.

```yaml
apiVersion: artifact.apicur.io/v1alpha1
kind: Artifact
metadata:
name: avro-example
spec:
artifactId: pests-record
name: pets
description: "Avro record for Pet entity"
type: AVRO
labels:
- avro
- kafka
content: |
{"namespace": "example.avro",
"type": "record",
"name": "Pet",
"fields": [
{"name": "name", "type": "string"},
{"name": "holderId", "type": ["int", "null"]},
{"name": "type", "type": ["string", "null"]}
]
}
```
You can find more artifact examples in [`dist/kubernetes/examples`](./dist/kubernetes/examples)

This project provides a Kubernetes Custom Resource Definition that represents an Artifact Version in Apicurio Registry. The declaration can be found in the `api` module.

Currently this project only consists of a controller responsible of the synchronization of an Apicurio Registry instance against `Artifact` CRDs in Kubernetes.
The controller ensures the `Artifacts` exist in the target Apicurio Registry instance. The controller code can be found in the `sync` module.

# How to deploy this?
You can find two examples of how to deploy this operator in the `deploy` folder.

The manifests in the `simple` folder are an example of a Kubernetes-only deployment of Apicurio Registry. This deploys the in-memory storage variant of Apicurio Registry (`quay.io/apicurio/apicurio-registry-mem`) and also deploys the content-sync controller as a sidecar to the registry. This way we can create artifacts in the registry through Kubernetes CRDs and the long term storage for the registry is Kubernetes.

You can deploy the `simple` installation like this:

```
kubectl apply -f https://raw.githubusercontent.com/Apicurio/apicurio-registry-content-sync-operator/main/deploy/simple.yaml
```

The manifests in the `standalone` folder are an example of a deployment of this operator in isolation. With this deployment method it's assumed the registry is already deployed. The target Apicurio Registry instance is configured with the env var `APICURIO_REGISTRY_URL` located in the `03-deployment.yaml` file.

The `simple` manifests folder is the only one that works out of the box, the `standalone` one you may have to tweak it to point to your own Apicurio Registry.