Skip to content
This repository has been archived by the owner on Nov 29, 2024. It is now read-only.

Commit

Permalink
Add overview section to README (#16)
Browse files Browse the repository at this point in the history
  • Loading branch information
laurentluce authored Nov 29, 2024
1 parent 5217dd6 commit 68ac83b
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 6 deletions.
25 changes: 19 additions & 6 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,24 @@

Implementation of [Kardinal](https://github.com/kurtosis-tech/kardinal) as a K8S Operator.

## Overview

The Kardinal operator watches the cluster K8S resources, generates a cluster topology and applies changes to satisfy the cluster topology. One difference with today is that the operator only manages what needs to be added to the user cluster (dev services, network resources…). The operator does not reconcile user resources. We introduce some k8s custom resources: service dependencies, flows, plugins and templates. Those resources will be namespaced.

The operator performs the same operation each time one of the watched Flow custom resources is added or removed.

- Generate the base cluster topology from the list of services, dependencies, deployments, gateways…
- Generate flow topologies from the list of flows, plugins and templates. Every operation performed by the operator needs to be idempotent which means the plugins need to be idempotent.
- Merge the topologies
- Generate the K8s resources needed (dev services, network resources…) to satisfy the merged topology and reconcile the cluster.

![](images/overview.png)

## Install

### Requirements

Istio is required and your namespaces should be labeled for injection.
Istio is required and your namespaces should be labeled for injection.

```
istioctl manifest install --set profile=default
Expand Down Expand Up @@ -68,7 +81,7 @@ make run (Run operator against your local cluster)
Manage custom resources with kubectl:

```
# Create a flow
# Create a flow
kubectl create -f ./ci/flow-test.yaml
# Delete a flow
Expand All @@ -77,7 +90,7 @@ kubectl delete -f ./ci/flow-test.yaml
# Get all flows in namespace
kubectl get flows -n baseline
# Describe a flow by its name
# Describe a flow by its name
kubectl describe flows flow-test -n baseline
```

Expand Down Expand Up @@ -105,9 +118,9 @@ kubectl describe flows flow-test -n baseline

#### Gateway

If you previously ran `Kardinal Manager`, you may already have a `gateway-istio` deployment in your cluster. This could lead to requests being
routed through it instead of the `gateway-istio` deployment in the `baseline` namespace. This issue arises because a gateway resource may
still exist. We recommend removing it —only if you're certain it was created by Kardinal— before deploying the `./ci/obd-demo.yaml` manifest.
If you previously ran `Kardinal Manager`, you may already have a `gateway-istio` deployment in your cluster. This could lead to requests being
routed through it instead of the `gateway-istio` deployment in the `baseline` namespace. This issue arises because a gateway resource may
still exist. We recommend removing it —only if you're certain it was created by Kardinal— before deploying the `./ci/obd-demo.yaml` manifest.
You can do this with the following command: `kubectl delete Gateway gateway`

[api-design-doc]: https://book.kubebuilder.io/cronjob-tutorial/api-design
Expand Down
Binary file added images/overview.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit 68ac83b

Please sign in to comment.