You are viewing the development docs which are in progress. There is no guarantee that the development documentation will be accurate, including instructions, links, and other information. For the latest stable documentation, click here.
Installation on Google Cloud
This page describes how to install Kairos on Google Cloud after you have created a disk image. Since release v3.3.1, Kairos pipeline is pushing a public OS image to Google Cloud which you can use. If you want to build a custom image, you can follow the instructions in the Creating Custom Cloud Images page.
Prerequisites
- A Google Cloud account with permissions to create VMs.
- A Google Cloud compatible image of Kairos. You can use the public image provided by Kairos (see below) or build your own image and upload it to your google project (check how the Kairos CI does it).
Deploy a VM
Unfortunately Google Cloud doesn’t allow users to search among public images in different projects. One has to know the exact project and name of the image they intend to use, even if its publicly accessible to all authenticated users. Using the public image seems to only be possible through the command line because of the above.
- Make sure you are authenticated with the cli: gcloud auth login
- Create a VM using the latest Kairos image:
Note
As described below, it is possible to reset to any desired image on first boot. That’s the reason only one Kairos flavor is published in Google Cloud (Ubuntu 24.04). This allows us to save costs and time by not pushing unnecessary artifacts.Verify the Image
To ensure you’re using a genuine Kairos image in Google Cloud, make sure the image you are going to use is in the Kairos team’s Google Cloud project (palette-kairos).
You can verify the image using the Google Cloud CLI:
gcloud compute images describe <IMAGE_NAME> --project palette-kairos --format="table(name,description,status)"
Replace <IMAGE_NAME> with the name of the image. The output will show you the name, description, and status of the image. If the image doesn’t belong to the Kairos project, no image will be found.
Note
As described below, it is possible to reset to any desired image on first boot. That’s the reason only one Kairos flavor is published in Google Cloud (Ubuntu 24.04). This allows us to save costs and time by not pushing unnecessary artifacts.gcloud --project  <your_project_here> compute instances create kairos-vm-test \
  --image=projects/palette-kairos/global/images/kairos-ubuntu-24-04-core-amd64-generic-. \
  --image-project=palette-kairos \
  --zone=europe-central2-c \
  --metadata-from-file=user-data=<path_to_your_cloud_config> \
  --boot-disk-size=40G
Connect to the instance:
gcloud compute connect-to-serial-port kairos-vm-test
By passing a file to --metadata-from-file=user-data=<your_file_here> you can pass a cloud config to Kairos. You should at least specify a user and a password (or SSH key) if you need to SSH to the instance (Check the Getting started page for some examples).
When the instance boots for the first time, it boots into “auto-reset mode” by default. This means, that Kairos will “install” itself on the first boot and then reboot. You can specify a different image to be installed using a block like the following in the cloud config:
reset:
  source: "oci:quay.io/kairos/opensuse:leap-15.6-standard-amd64-generic-v3.5.5-k3sv1.34.1-k3s1"
This will reset to the specified image on the first boot instead of the image booted. Once the instance is running, you can access it via SSH. Make sure reset has completed and the system has rebooted into “active” mode. The following command should report “active_boot”:
kairos-agent state get boot
(It it reports recovery_boot, the system is still in the installation process. Wait a few minutes and try again.)