Files
homelab/active/software_osbuild/image_builder.md
2026-01-05 10:01:11 -05:00

2.7 KiB

Image Builder

Builds Fedora/RHEL/Centos images like Packer but for Red Hat.

https://osbuild.org/docs/user-guide/blueprint-reference/

Default credentials for included images is:

username: ducoterra

password: osbuild

Warning

From the Red Hat Documentation:

You cannot build an operating system image that differs from the RHEL image builder host. For example, you cannot use a RHEL system to build Fedora or CentOS images.

Installing

# Install the packages
dnf install -y osbuild-composer composer-cli

# Start/enable the service
systemctl enable --now osbuild-composer.socket

# Optional: add your user to the weldr group
sudo usermod -aG weldr $USER

# Optional: cockpit dependency
dnf install -y cockpit-composer

# Optional: allow security profiles
dnf install openscap-scanner scap-security-guide

Building Images

  1. Create a toml file describing your image

    See fedora42-base.toml for an example.

  2. Push the toml to composer

    composer-cli blueprints push active/software_osbuild/fedora42-base.toml
    
    # List blueprints
    composer-cli blueprints list
    
  3. Generate the image

    # List image types
    composer-cli compose types
    
    # Build the image
    composer-cli compose start fedora42-base qcow2
    
    # Check status
    watch composer-cli compose status
    
    # Download logs if error
    cd /tmp && composer-cli compose logs 52963ac9-b680-4def-baaf-252845f0e3fe
    
    # Delete failed images
    composer-cli compose list failed -j | jq '.[].body.failed.[]?.id' | xargs -I '%' composer-cli compose delete '%'
    
    # Delete successful images
    composer-cli compose list finished -j | jq '.[].body.finished.[]?.id' | xargs -I '%' composer-cli compose delete '%'
    
  4. Run the image

    # List your images
    composer-cli compose list finished
    
    # Download the image
    composer-cli compose image --filename active/software_osbuild/secrets/fedora43-base.qcow2 image-uuid
    
    # Test with qemu
    virt-install \
    --name "fedora43-base" \
    --boot uefi,firmware.feature0.name=secure-boot,firmware.feature0.enabled=no \
    --cpu host-passthrough --vcpus sockets=1,cores=8,threads=2 \
    --ram=8192 \
    --os-variant=fedora41 \
    --network bridge:virbr0 \
    --graphics none \
    --console pty,target.type=virtio \
    --import --disk "path=active/software_osbuild/secrets/fedora43-base.qcow2,bus=virtio"
    

Image Build and Watch One Liner

composer-cli blueprints push active/software_osbuild/fedora43-base.toml && \
composer-cli compose start fedora43-base qcow2 && \
watch composer-cli compose status