Go to file
Jonathan Lebon 230c105895 Merge branch 'drop-bib' into 'main'
containerfile: Drop use of bootc-image-builder

See merge request fedora/bootc/base-images!58
2024-10-04 12:04:32 +00:00
tier-0 tier-0: remove gdisk and bootc has Rust create instead 2024-09-30 22:07:51 +08:00
tier-1 tier-1: drop a bunch of redundant packages 2024-09-18 15:32:40 -04:00
tier-x tier-x: explicitly list podman, skopeo 2024-09-20 11:15:19 -04:00
.gitlab-ci.yml CI: also build tier-0 and tier-x 2024-09-17 22:35:11 -04:00
.mdl_style.rb Update .mdl_style.rb 2023-11-09 16:14:45 +02:00
.mdlrc Update .mdlrc 2023-11-09 16:18:33 +02:00
.pre-commit-config.yaml chore(deps): update pre-commit hook pre-commit/pre-commit-hooks to v4.6.0 2024-06-03 00:05:58 +00:00
COPYING Enable pre-commit 2023-10-30 22:27:12 +02:00
Containerfile containerfile: Drop use of bootc-image-builder 2024-10-03 16:28:49 -04:00
LICENSE Initial split from Fedora CoreOS 2022-12-09 15:32:25 -05:00
README.md Merge branch 'more-doc-tiers' into 'main' 2024-09-18 20:59:16 +00:00
fedora-bootc-config.json Only rawhide 2024-05-28 19:53:56 +03:00
fedora-bootc.yaml Add fedora-repos-archive 2024-05-28 17:15:53 -04:00
fedora-generic.yaml Add fedora-repos-archive 2024-05-28 17:15:53 -04:00
fedora-tier-0.yaml Add fedora-repos-archive 2024-05-28 17:15:53 -04:00
fedora-tier-1.yaml CI: also build tier-0 and tier-x 2024-09-17 22:35:11 -04:00
fedora-tier-x.yaml tier-x: new tier for cross-variant collaboration 2024-09-16 16:52:36 -04:00
fedora.repo fedora.repo: Drop trailing whitespace 2024-04-18 16:33:36 -04:00
renovate.json Update renovate.json 2024-08-21 07:22:28 +00:00

README.md

Fedora bootc base images

Create and maintain base bootable container images from Fedora packages.

Motivation

The original Docker container model of using "layers" to model applications has been extremely successful. This project aims to apply the same technique for bootable host systems - using standard OCI/Docker containers as a transport and delivery format for base operating system updates.

Building images

The current default user experience is to build layered images on top of the official binary base images produced and tested by this project. See the documentation5 for more info.

You can build custom base images by forking this repository; however, https://gitlab.com/fedora/bootc/tracker/-/issues/32 tracks a more supportable mechanism that is not simply forking. For more information see6.

Build process

Building the images in this repo can be done with podman build, but note the build process uses a special podman-ecosystem specific mechanism to create fully custom images while inside a Containerfile. You need to enable some privileges as nested containerization is required.

podman build --security-opt=label=disable --cap-add=all \
  --device /dev/fuse -t localhost/fedora-bootc .

See the Containerfile for more details. This builds the default tier-1 image.

Deriving

You are of course also free to fork, customize, and build base images yourself. See this page6 of the documentation for more information.

Tiers

There are currently 3 tiers:

  • tier-1: This image is the default, what is published as https://quay.io/repository/fedora/fedora-bootc
  • tier-0: This image is more of a convenient centralization point for CI and curation around a package set that we can all agree is the rough minimum necessary for a usable system. It's not meant to be used as is, but layered upon.
  • tier-x: This image is not intended for end-users. It's the shared base used by all image-based Fedora variants (IoT, Atomic Desktops, and CoreOS). Changes to this tier may be done without accounting for external users. To build this, pass --build-arg=MANIFEST=fedora-tier-x.yaml to the build command above.

tier-1 inherits from tier-x and tier-x in turn inherit from tier-0.

All non-trivial changes to tier-0 and tier-x should be ACKed by at least one stakeholder of each Fedora variant WGs.

More information

Documentation: https://docs.fedoraproject.org/en-US/bootc/

Badges

Badge Description Service
Renovate Dependencies Renovate
Pre-commit Static quality gates pre-commit