Command Line Interface for IOC Management#
The python project edge-containers-cli is installed as part of the Python section of the initial tutorial Set up a Developer Workstation. It provides a command line function ec
with support for managing and monitoring IOC instances.
This tool is only required if you are deploying to Kubernetes. Docker compose provides a very similar set of commands for local deployment. Also note that ec
supports both ArgoCD and pure Helm deployments. The tutorials will use ArgoCD, for information on Helm based deployments see Pure Helm Deployments .
The CLI is just a thin wrapper around the underlying tools that do the real work:
- kubectl:
the command line interface to the Kubernetes APIs
- helm:
the command line interface to the Kubernetes Helm package manager
- git:
the git version control system client
- argocd:
the ArgoCD command line interface
ec
is useful because it saves typing and provides a consistent interface when working on multiple services repositorys. This is because it uses the environment setup by the beamline repo’s environment.sh
script. See The Environment Configuration File.
To see the available commands, run ec --help
.
It may be instructive to understand the underlying tools and how they are being called. For this reason ec
supports a -v
option to show the underlying commands being executed. e.g.
(venv) (main) [hgv27681@pc0116 bl47p]$ ec -v ps kubectl get namespace p47-iocs -o name helm list -n p47-iocs -o json kubectl get pods -n p47-iocs -o jsonpath='{range .items[*]}{..labels.app}{","}{..containerStatuses[0].ready}{","}{..containerStatuses[0].restartCount}{","}{.status.startTime}{"\n"}{end}' name ready restarts started namespace app_version bl47p-ea-dcam-01 true 0 2024-02-09T12:34:18Z p47-iocs 2024.2.1b2 bl47p-ea-dcam-02 true 0 2024-02-09T15:10:06Z p47-iocs 2024.2.1 bl47p-ea-panda-01 true 0 2024-02-09T21:57:23Z p47-iocs 2024.2.1b2 bl47p-mo-ioc-01 true 0 2024-02-09T15:42:24Z p47-iocs 2024.2.1 epics-opis true 0 2024-02-09T21:55:21Z p47-iocs 2024.2.2 (venv) (main) [hgv27681@pc0116 bl47p]$