This repository contains the operator to perform model-based meta-orchestration within a Cloud-to-Edge continuum as described by FLUIDOS.
The operator assumes the following to be available within the system:
- Kubernetes version >= 28.1.0
- REAR (node) functionality version >= 0.0.4
- Liqo version >= 0.10.2
Moreover, the interaction with the operator assumes:
- fluidos-kubectl-plugin version >= 0.0.3
To run the operator in development mode, the following is required:
- python >= 3.11
The operator can be executed in two main modes, namely development mode and production mode. The former refers to the the operator being executed within a local environment against a running kubernetes cluster (usually Kind). The latter, on the other hand, refers to the operator running within a kubernetes cluster.
Development mode assumes access to a Kubernetes cluster. An example of cluster, using kind is available here.
# start kind
kind create cluster --name foo --config utils/cluster-multi-worker.yaml --kubeconfig utils/examples/dublin-kubeconfig.yaml
# install CRD
kubectl apply -f utils/fluidos-deployment-crd.yaml
# optionally, install FLUIDOS node CRDs
kubectl apply -f tests/node/crds
# locally install the fluidos package, in editing mode
pip install -e .
# start FLUIDOS operator
kopf run --verbose -m fluidos_model_orchestrator
The shell will provide the log of the execution of the operator.
When deploying directly on a cluster, one can leverage the following utility steps:
# build docker image
docker build -t fluidos-mbmo:latest . && docker push
# install CRD
kubectl apply -f utils/fluidos-deployment-crd.yaml
# install operator to cluster
kubectl apply -f utils/fluidos-deployment.yaml
Note that the docker image must be available to the cluster. If the cluster has been created with kind, the image must be loaded using kind load docker-image fluidos-mbmo:latest
. Also, note that if the environment is using podman instead of docker, then alternative steps are required. Namely, the docker image must be loaded into the cluster nodes via the following steps:
podman save fluidos-mbmo:latest -o /tmp/fluidos-mbmo-latest.tar && kind load image-archive /tmp/fluidos-mbmo-latest.tar
.
TODO
Please read CONTRIBUTING.md for details on our process for submitting pull requests to us, and please ensure you follow the CODE_OF_CONDUCT.md.
To install the environment for the local development, read DEVELOPMENT.md.
We use SemVer for versioning. For the versions available, see the releases on this repository.
This project is licensed under the Apache License — version 2.0 see the LICENSE file for details.