This pins to static tags for all airship owned images: airship/images: all: 053c992218601cc49fd4a595ee4873380b132408 airship/airshipctl: aiap-*: 892bb6a16d53a0f43571284db83901bef53ed440 released krm functions: v2.0.2 (030bb123d8fedd39125dd6eae92f48e0d32a7469) toolbox krm function (unreleased): 346196e6c1d0dda202464133377aa3ec586719e4 Change-Id: I79eedaf0f61c1bcda58640aed0540e1102b23dc8 Signed-off-by: Sean Eagan <seaneagan1@gmail.com>
Airship in a Pod
Airship in a pod is a Kubernetes pod definition which describes all of the components required to deploy a fully functioning Airship 2 deployment. The pod consists of the following "Task" containers:
airshipctl-builder
: This container builds the airshipctl binary and makes it available to the other containersinfra-builder
: This container creates the various virtual networks and machines required for an Airship deploymentrunner
: The runner container is the "meat" of the pod, and executes the deployment
The pod also contains the following "Support" containers:
libvirt
: This provides virtualisationsushy-tools
: This is used for its BMC emulatordocker-in-docker
: This is used for nesting containers*nginx
: This is used for image hosting
Prerequisites
In order to deploy Airship in a Pod for development, you must first have a working Kubernetes cluster. This guide assumes that a developer will deploy using minikube:
sudo -E minikube start --driver=none
Usage
Since Airship in a Pod is just a pod definition, deploying and using it is as simple as deploying and using any Kubernetes pod.
Deploy the Pod
kubectl apply -f airship-in-a-pod.yaml
View Pod Logs
kubectl logs airship-in-a-pod -c $CONTAINER
Interact with the Pod
kubectl exec -it airship-in-a-pod -c $CONTAINER -- bash
where $CONTAINER
is one of the containers listed above.
Output
Airship-in-a-pod produces the following outputs:
- The airshipctl repo and associated binary used with the deployment
- A tarball containing the generated ephemeral ISO, as well as the configuration used during generation.
These artifacts are placed at ARTIFACTS_DIR
(defaults to /opt/aiap-artifacts`).
Caching
As it can be cumbersome and time-consuming to build and rebuild binaries and
images, some options are made available for caching. A developer may re-use
artifacts from previous runs (or provide their own) by placing them in
CACHE_DIR
(defaults to /opt/aiap-cache
). Special care is needed for the
caching:
- If using a cached
airshipctl
, theairshipctl
binary must be stored in the$CACHE_DIR/airshipctl/bin/
directory, and the developer must have setUSE_CACHED_AIRSHIPCTL
totrue
. - If using a cached ephemeral iso, the iso must first be contained in a tarball named
iso.tar.gz
, must be stored in the$CACHE_DIR/
directory, and the developer must have setUSE_CACHED_ISO
totrue
.