Skip to content

Latest commit

 

History

History
 
 

orchestrator

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Orchestrator

This chart is used to deploy the orchestrator application which can be used to deploy benchmarking clusters, run benchmarks on them, etc. This chart can be deployed on any Lokomotive cluster regardless or the region, the underlying architecture or cloud provider.

General Usage

Generate Ephemeral SSH Key Pair

Generate SSH key pair, which will be used to install the benchmarking clusters:

export KEY_PATH="${HOME}/.ssh/id_rsa.bc-${RANDOM}"
ssh-keygen -t rsa -b 8192 -f "${KEY_PATH}" -N "" -C "<please provide email id>"

Install

Run the following command to install the helm chart:

helm install \
    --values=values-real.yaml \
    --set-file runScript=run.sh \
    --set-file sshKey.public="${KEY_PATH}".pub \
    --set-file sshKey.private="${KEY_PATH}" \
    --create-namespace \
    --namespace orchestrator \
    orchestrator .

Copy the the values.yaml file and make changes as necessary and rename it to values-real.yaml.

Update the path of the SSH keys as required.

Upgrade

helm upgrade \
    --values=values-real.yaml \
    --set-file runScript=run.sh \
    --set-file sshKey.public="${KEY_PATH}".pub \
    --set-file sshKey.private="${KEY_PATH}" \
    --namespace orchestrator \
    orchestrator .

Delete

helm uninstall orchestrator
kubectl delete ns orchestrator

Writing a script

  • Write a script that deploys the cluster and installs the components on Lokomotive cluster.
  • Followed by cluster and component installation design your script to deploy target benchmarking applications.
  • Start off using the scaffold provided in run.sh.
  • Take inspiration from the existing run-smi-benchmark.sh

Clean up benchmarking clusters

Exec into the debug pod:

kubectl -n orchestrator exec -it $(kubectl -n orchestrator get pod -l app=debug-jobs -o name) bash

Run the clean up script:

bash /scripts/cleanup.sh

Debug failed cluster

Exec into the debug pod:

kubectl -n orchestrator exec -it $(kubectl -n orchestrator get pod -l app=debug-jobs -o name) bash

You can find all the cluster assets and related config in the /clusters directory. You can use these assets to interact with the cluster.