diff --git a/README.md b/README.md index e5dbe28..9551d32 100644 --- a/README.md +++ b/README.md @@ -36,11 +36,12 @@ and quote (report). ## 3. Deployment -There are 2 options creating a confidential cluster. +There are 3 options creating a confidential cluster. - Create a few confidential VMs (CVMs) and deploy Kubernetes within them. The CVMs can be on local hosts if you have supported hardware. The CVMs can also be applied from CSP. The document [csp_cvm.md](./deployment/csp_cvm.md) shows how to apply for a TD on Google Cloud or Azure and start a Kubernetes cluster in the single confidential node. - Create [Confidential GKE node](https://cloud.google.com/blog/products/identity-security/announcing-general-availability-of-confidential-gke-nodes) on Google cloud. +- Create a Constellation based confidential cluster on top of a TDX machine. Follow the steps [here](./deployment/constellation.md) to deploy the cluster. -Find details in [deployment guide](./deployment/). +Find details in [deployment guide](./deployment/Constellation/constellation.md). diff --git a/deployment/Constellation/constellation.md b/deployment/Constellation/constellation.md new file mode 100644 index 0000000..ed4ddd7 --- /dev/null +++ b/deployment/Constellation/constellation.md @@ -0,0 +1,108 @@ +# Deployment Guide for Constellation based Confidential Cluster + +This guide introduces the steps to deploy a confidential cluster through [Constellation](https://github.com/edgelesssys/constellation), which a project initiated by Edgeless Sys. Following the steps, users are able to create a Constellation cluster composing of several TDs created by QEMU on a bare metal TDX machine. + +As mentioned in Constellation documentation, + +## Prerequisites + +### Setup TDX host + +Please follow the steps [here](https://github.com/canonical/tdx?tab=readme-ov-file#4-setup-tdx-host) to setup the TDX host. + +### Check prerequisites and install dependencies + +Check the following prerequisites: + +* 20GB (minimum), better 40 GB disk space (required if you want to cross compile for all platforms) +* 16GB of unutilized RAM for a full Bazel build. +* [Latest version of Go](https://go.dev/doc/install). +* Unless you use Nix / NixOS: [Bazelisk installed as `bazel` in your path](https://github.com/bazelbuild/bazelisk/releases). +* We require Nix to be installed. It is recommended to install nix using the [determinate systems installer](https://github.com/DeterminateSystems/nix-installer) (or to use NixOS as host system). +* [Docker](https://docs.docker.com/engine/install/). Can be installed with these commands on Ubuntu 22.04: `sudo apt update && sudo apt install docker.io`. As the build spawns docker containers your user account either needs to be in the `docker` group (Add with `sudo usermod -a -G docker $USER`) or you have to run builds with `sudo`. When using `sudo` remember that your root user might (depending on your distro and local config) not have the go binary in it's PATH. The current PATH can be forwarded to the root env with `sudo env PATH=$PATH `. + + +## Build Constellation + +To leverage bare metal TDX machine to build up Constellation cluster, user need to apply several patches to the constellation repository. Follow the steps to build Constellation for QEMU TDX option: + +### Step 1: Clone Constellation repo and apply patches. + +```bash +# clone the constellation repo and apply patches. +git clone https://github.com/edgelesssys/constellation.git +git checkout fe65a6da76d03f0bed841ae36f33ff22d2567700 +git checkout -b constellation-qemu-tdx +git apply constellation_qemu_tdx.patch +``` + +### (Optional) Step 2: Setup proxy if required + +### Step 3: Build Constellation image for QEMU-TDX option +Build a Constellation image that works for QEMU-TDX option. + +```bash +cd constellation +bazel build //image/system:qemu_qemu-tdx_stable +``` + +### Step 4: Build the Constellation CLI to startup confidential cluster + +A Constellation CLI is required to bootstrap the confidential cluster. Follow the steps here to create a new image for the QEMU-TDX option. +```bash +mkdir build + +cd build +# replace the container prefix to your hub prefix. e.g. docker.io/user/ +bazel run //:devbuild --cli_edition=oss --container_prefix=/constellation +``` + +## Run Constellation + +Now we are ready to run the Constellation confidential cluster. Follow the steps to setup the configuration and boot up the cluster. + +```bash +# copy the prebuilt images to the build/ directory +cp ../bazel-bin/image/system/qemu_qemu-tdx_stable/constellation.* . + +# create a image info file to hold the image path and remember to replace the username and path in the input. +cat > constellation_v2_ref_-_stream_stable_v2.17.0_image_info.json << EOF +{"ref":"-","stream":"stable","version":"v2.17.0","list":[{"csp":"QEMU","attestationVariant":"qemu-tdx","reference":"file:///home///constellation/build/constellation.raw"}]} +EOF + +# generate a constellation-conf.yaml to hold all the configurations. +./constellation config generate qemu -a qemu-tdx +``` + +User need to modify the configuration before starting up the cluster. Modification required are listed here: + +1. add `v2.17.0` as the value of `image`. +2. change the value of `libvirtSocket` to `qemu:///system` or path to local QEMU socket to leverage the local QEMU instead of docker. +3. check the value of `metadataAPIServer` and make sure it equals to the value you just pushed in the CLI generation step. +4. change the measurements of TDX like what shows in the picture + +User could then use the simple command to start up the Constellation confidential cluster. +```bash +# add '--debug' flag to check the debug information +./constellation apply -y --debug +``` + +After one minute or two, user is able to find a working cluster on the machine using `virsh`: +```bash +virsh list | grep constell +constell-control-plane-322cc81a-0 running +constell-control-plane-322cc81a-1 running +constell-control-plane-322cc81a-2 running +constell-worker-60bb1fc2-0 running +``` + +## Clean up or start a new cluster +To clean up the confidential cluster started by the Constellation CLI. Use the steps below: +```bash +# terminate the cluster +./constellation terminate -y + +# remove existing master secret before restarting a new cluster +rm -f constellation-mastersecret.json +``` +