How to build fedora system images using Image Builder

How to build fedora system images using Image Builder

fedora_systemimage_builder

Here in this article we will look Customised System Image Builder tool which can be used to build custom system images in different formats. We will be installing the OS Image Builder tool and use the CLI interface to build a custom image using a blueprint definition of the custom image.

Test Environment

Fedora 35 workstation

What is Image Builder

Image Builder tool helps in creating deployment ready customised system images like installation disks, virtual machines, cloud specific images or others. It automatically handles details of setup for each output type and is thus easier to use and faster to work with than manual methods of image creation. This service is provided by the osbuild-composer package. We can interact with this service either using the composer-cli tool or GUI plugin for web console.

What is Blueprint

Blueprint is customised system image definition written in plain text as Tom’s Obvious, Minimal Language (TOML) format. It defines the listing of the packages and other customisation that would be part of the system image.

What is Compose

Compose is nothing but the individual builds of a system image based on particular version of a particular blueprint.

What is Customisation

Customisation are specifications for the system, which are not packages. This includes users, groups, and SSH keys.

If you are interested in watching the video. Here is the YouTube video on the same step by step procedure outlined below.

Procedure

Step1: Install Image Builder tool

As a first step let’s install the Image Build tool along with other packages as shown below.

sudo dnf install osbuild-composer composer-cli cockpit-composer bash-completion

Image Builder has its own set of official repositories defined in the /usr/share/osbuild-composer/repositories directory. To override the official repositories, you must define overrides in /etc/osbuild-composer/repositories. This directory is for user defined overrides and the files located here take precedence over those in the /usr directory.

Here is the default location of the repository files once the package is installed.

Location: /usr/share/osbuild-composer/repositories

-rw-r--r--. 1 root root 15520 Apr 20 17:57 fedora-36.json
-rw-r--r--. 1 root root 15520 Apr 20 17:57 fedora-35.json
-rw-r--r--. 1 root root 15520 Apr 20 17:57 fedora-34.json

Step2: Enable service on startup

We will enable this Image builder service to started using the socket when its called as shown below.

sudo systemctl enable --now osbuild-composer.socket
sudo systemctl enable --now cockpit.socket

Step3: List Supported Image formats

Ones the packages are installed, let’s use the composer cli tool to list the types for system images formats that can be created as shown below.

sudo composer-cli compose types

Output:

ami
fedora-iot-commit
oci
openstack
qcow2
vhd
vmdk

Step4: Create Image Builder Blueprint using CLI

Let’s create a blupeprint definition file as shown below in which we are defining two packages to be installed by default which are nginx and sscg in our custom system image that we will be creating in further steps below.

mkdir imagebuilder; cd imagebuilder
cat fed36-customized.toml

Output:

name = "fed36-customized"
description = "custom fedora 36 image"
version = "0.0.1"
modules = []
groups = []
[[packages]]
name = "nginx"
version = "*"
[[packages]]
name = "sscg"
version = "*"

Now, we will need to push this blueprint as shown below and validate its available in the list of blueprints.

sudo composer-cli blueprints push fed36-customized.toml 
sudo composer-cli blueprints list

Make sure the components and versions listed in the blueprint and their dependencies are valid.

sudo composer-cli blueprints depsolve fed36-customized

Step5: Create System Image using the blueprint

Now, let’s create our customised system image of type vmdk as shown below. Once the command is triggered it will take few minutes for the image to be created.
You can track the status of the image creating using the below commands.

sudo composer-cli compose start fed36-customized vmdk

Output:

Compose 248b7555-c132-4341-9860-de0ede726249 added to the queue

Check the compose status.

sudo composer-cli compose status

Output:

248b7555-c132-4341-9860-de0ede726249 FINISHED Thu May 12 18:15:54 2022 fed36-customized 0.0.1 vmdk             2147483648

Step6: Download the System Image

Once the customised system image creation is completed. You can download the image using the below command.

sudo composer-cli compose image 248b7555-c132-4341-9860-de0ede726249

This downloaded image now can be used to create your customised Fedora OS based virtual machine in VMware.

You can refer to the following user guide documentation for more information on the Image Builder tool.

Hope you enjoyed reading this article. Thank you..