constellation/image/README.md

75 lines
3.1 KiB
Markdown

## Setup
Ensure you have Nix installed. This is a requirement for the following steps.
Consult the [developer docs](/dev-docs/workflows/build-develop-deploy.md) for more info.
At the very least, `nix` should be in your PATH.
Building the image also requires `newuidmap` and `newgidmap` to be present in the PATH. On Debian and Ubuntu, these can be sourced through
the `uidmap` package.
## Build
You can build any image using Bazel.
Start by querying the available images:
```sh
bazel query //image/system/...
```
You can either build a group of images (all images for a cloud provider, a stream, ...) or a single image by selecting a target.
```sh
bazel build //image/system:azure_azure-sev-snp_stable
```
The location of the destination folder can be queried like this:
```sh
bazel cquery --output=files //image/system:azure_azure-sev-snp_stable
```
## Build and Upload
Similarly, you can also build and upload images to the respective CSP within a single step with the `upload_*` targets.
```sh
bazel run //image/system:upload_aws_aws-sev-snp_console -- --ref deps-image-fedora-40 --upload-measurements
```
The `--ref` should be the branch you're building images on. It should **not contain slashes**. Slashes should be replaced with dashes to
not break the filesystem structure of the image storages.
Optionally, the `--upload-measurements` option can be used to specify that measurements for the image should be uploaded, and `--fake-sign` specifies
that a debugging signing key should be used to sign the measurements, which is done for debug images.
## Kernel
The Kernel is built from the srpm published under [edgelesssys/constellation-kernel](https://github.com/edgelesssys/constellation-kernel).
We track the latest longterm release, use sources directly from [kernel.org](https://www.kernel.org/) and build the Kernel using the steps specified in the
srpm spec file.
After building a Kernel rpm, we upload it to our CDN and use it in our image builds.
## Upgrading to a new Fedora release
- Search for the old Fedora releasever in the `image/` directory and replace every occurence (outside of lockfiles) with the new releasever
- Search for Fedora container images in Dockerfiles and upgrade the releasever
- Regenerate the package lockfile: `bazel run //image/mirror:update_packages`
- Build test images locally:
- `bazel query //image/system:all` (pick an image name from the output)
- `bazel build //image/system:IMAGE_NAME_HERE` (replace with an actual image name)
- Let CI build new images and run e2e tests
- Upgrade kernel spec under [edgelesssys/constellation-kernel](https://github.com/edgelesssys/constellation-kernel) to use new releasever
## Adding new packages to the image
- Find the package (i.e. it's _package name_) on [Koji](https://koji.fedoraproject.org/koji/)
- Add the package to the corresponding section in `./base/mkosi.conf`
- If the package is required to be present in the initrd, add it to `./initrd/mkosi.conf`
- Add the package to `./mirror/packages.txt`
- Update the package mirror:
```sh
bazel run //image/mirror:update_packages
```
- Build new images (e.g. via CI) and run e2e tests