/assisted-installer

Primary LanguageGoApache License 2.0Apache-2.0

OpenShift Assisted Installer

The OpenShift Assisted Installer provides for easy provisioning of new bare metal machines and creation of OpenShift clusters. The Assisted Installer is meant to run on FCOS or RHCOS liveCD images. The Assisted Installer uses CoreOS Ignition as a configuration format. The ignition files are created and stored by Assisted Installation Service.

The Assisted Installer is executed by the Assisted Installation Service. Once the cluster installation begins (after host discovery), each host will get the relevant install command from the service. For example:

sudo podman run -e CLUSTER_ID=<clusterID> -e BUCKET=<S3 bucket> -e S3_URL=<S3 url> -e DEVICE=<boot disk> -v /dev:/dev:rw --privileged --pid=host  quay.io/openshift/assisted-installer:latest -r <node role>

There are 3 different roles for installing a node using the assisted installer:

  • master
  • worker
  • bootstrap

Unlike most OpenShift installers, the assisted installer requires a minimum of 3 nodes and doesn't require an auxiliary bootstrap node.
Instead, the Assisted Installer will pivot the bootstrap to become a master node once the control plane is running on 2 other master nodes.

Bootstrap node installation flow:

The Assisted Installer will:

  1. fetch the bootstrap ignition file (currently from S3 but will change soon) and utilize the MCO container for writing the configuration to disk (using once-from option).
  2. start the bootstrap services (bootkube.service, approve-csr.service, progress.service), at this point the bootstrap will start a temporary control plane.
  3. fetch the cluster kubeconfig from the assisted-service and wait for 2 master nodes to appear.
  4. patch the etcd configuration to allow etcd to start with less than 3 members (<4.7 only).
  5. wait for 2 ready master nodes and for the bootkube service to complete.
  6. pivot to master by executing the master installation flow.

Master / worker node installation flow:

The Assisted Installer will:

  1. fetch the relevant ignition file and utilize coreos-installer to write the relevant CoreOS image and ignition to disk.
  2. trigger node reboot.

The node will start with the new CoreOS image and ignition, and will contact the machine-config-server running on the bootstrap node in order to complete the installation.

Known changes to be done:

  • Create a machine CR for the bootstrap node in order to approve the CSR for this node.
  • Optimize install time by storing the CoreOS image on the live CD rather than downloading it from the internet.
  • Use the relevant CoreOS image for the OCP release.
  • Get the ignition from the bm-inventory instead of S3.

Build

To build and push your image to docker registry just run make. You can change the default target, export INSTALLER environment variable to your docker registry

export INSTALLER=<registry>/<image-name>:<tag>
make