doc: Add full examples of compose configuration
JIRA: COMPOSE-3797 Signed-off-by: Lubomír Sedlář <lsedlar@redhat.com>
This commit is contained in:
parent
72bf795bd4
commit
014560f8bd
481
doc/examples.rst
Normal file
481
doc/examples.rst
Normal file
@ -0,0 +1,481 @@
|
|||||||
|
.. _examples:
|
||||||
|
|
||||||
|
Big picture examples
|
||||||
|
====================
|
||||||
|
|
||||||
|
Actual Pungi configuration files can get very large. This pages brings two
|
||||||
|
examples of (almost) full configuation for two different composes.
|
||||||
|
|
||||||
|
Fedora Rawhide compose
|
||||||
|
----------------------
|
||||||
|
|
||||||
|
This is a shortened configuration for Fedora Radhide compose as of 2019-10-14.
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
release_name = 'Fedora'
|
||||||
|
release_short = 'Fedora'
|
||||||
|
release_version = 'Rawhide'
|
||||||
|
release_is_layered = False
|
||||||
|
|
||||||
|
bootable = True
|
||||||
|
comps_file = {
|
||||||
|
'scm': 'git',
|
||||||
|
'repo': 'https://pagure.io/fedora-comps.git',
|
||||||
|
'branch': 'master',
|
||||||
|
'file': 'comps-rawhide.xml',
|
||||||
|
# Merge translations by running make. This command will generate the file.
|
||||||
|
'command': 'make comps-rawhide.xml'
|
||||||
|
}
|
||||||
|
module_defaults_dir = {
|
||||||
|
'scm': 'git',
|
||||||
|
'repo': 'https://pagure.io/releng/fedora-module-defaults.git',
|
||||||
|
'branch': 'master',
|
||||||
|
'dir': '.'
|
||||||
|
}
|
||||||
|
|
||||||
|
variants_file='variants-fedora.xml'
|
||||||
|
sigkeys = ['12C944D0']
|
||||||
|
|
||||||
|
# Put packages into subdirectories hashed by their initial letter.
|
||||||
|
hashed_directories = True
|
||||||
|
|
||||||
|
# There is a special profile for use with compose. It makes Pungi
|
||||||
|
# authenticate automatically as rel-eng user.
|
||||||
|
koji_profile = 'compose_koji'
|
||||||
|
|
||||||
|
# RUNROOT settings
|
||||||
|
runroot = True
|
||||||
|
runroot_channel = 'compose'
|
||||||
|
runroot_tag = 'f32-build'
|
||||||
|
|
||||||
|
# PKGSET
|
||||||
|
pkgset_source = 'koji'
|
||||||
|
pkgset_koji_tag = 'f32'
|
||||||
|
pkgset_koji_inherit = False
|
||||||
|
|
||||||
|
filter_system_release_packages = False
|
||||||
|
|
||||||
|
# GATHER
|
||||||
|
gather_method = {
|
||||||
|
'^.*': { # For all variants
|
||||||
|
'comps': 'deps', # resolve dependencies for packages from comps file
|
||||||
|
'module': 'nodeps', # but not for packages from modules
|
||||||
|
}
|
||||||
|
}
|
||||||
|
gather_backend = 'dnf'
|
||||||
|
gather_profiler = True
|
||||||
|
check_deps = False
|
||||||
|
greedy_method = 'build'
|
||||||
|
|
||||||
|
repoclosure_backend = 'dnf'
|
||||||
|
|
||||||
|
# CREATEREPO
|
||||||
|
createrepo_deltas = False
|
||||||
|
createrepo_database = True
|
||||||
|
createrepo_use_xz = True
|
||||||
|
createrepo_extra_args = ['--zck', '--zck-dict-dir=/usr/share/fedora-repo-zdicts/rawhide']
|
||||||
|
|
||||||
|
# CHECKSUMS
|
||||||
|
media_checksums = ['sha256']
|
||||||
|
media_checksum_one_file = True
|
||||||
|
media_checksum_base_filename = '%(release_short)s-%(variant)s-%(version)s-%(arch)s-%(date)s%(type_suffix)s.%(respin)s'
|
||||||
|
|
||||||
|
# CREATEISO
|
||||||
|
iso_hfs_ppc64le_compatible = False
|
||||||
|
create_jigdo = False
|
||||||
|
|
||||||
|
# BUILDINSTALL
|
||||||
|
buildinstall_method = 'lorax'
|
||||||
|
buildinstall_skip = [
|
||||||
|
# No installer for Modular variant
|
||||||
|
('^Modular$', {'*': True}),
|
||||||
|
# No 32 bit installer for Everything.
|
||||||
|
('^Everything$', {'i386': True}),
|
||||||
|
]
|
||||||
|
|
||||||
|
# Enables macboot on x86_64 for all variants and disables upgrade image building
|
||||||
|
# everywhere.
|
||||||
|
lorax_options = [
|
||||||
|
('^.*$', {
|
||||||
|
'x86_64': {
|
||||||
|
'nomacboot': False
|
||||||
|
},
|
||||||
|
'ppc64le': {
|
||||||
|
# Use 3GB image size for ppc64le.
|
||||||
|
'rootfs_size': 3
|
||||||
|
},
|
||||||
|
'*': {
|
||||||
|
'noupgrade': True
|
||||||
|
}
|
||||||
|
})
|
||||||
|
]
|
||||||
|
|
||||||
|
additional_packages = [
|
||||||
|
('^(Server|Everything)$', {
|
||||||
|
'*': [
|
||||||
|
# Add all architectures of dracut package.
|
||||||
|
'dracut.*',
|
||||||
|
# All all packages matching this pattern
|
||||||
|
'autocorr-*',
|
||||||
|
],
|
||||||
|
}),
|
||||||
|
|
||||||
|
('^Everything$', {
|
||||||
|
# Everything should include all packages from the tag. This only
|
||||||
|
# applies to the native arch. Multilib will still be pulled in
|
||||||
|
# according to multilib rules.
|
||||||
|
'*': ['*'],
|
||||||
|
}),
|
||||||
|
]
|
||||||
|
|
||||||
|
filter_packages = [
|
||||||
|
("^.*$", {"*": ["glibc32", "libgcc32"]}),
|
||||||
|
('(Server)$', {
|
||||||
|
'*': [
|
||||||
|
'kernel*debug*',
|
||||||
|
'kernel-kdump*',
|
||||||
|
]
|
||||||
|
}),
|
||||||
|
]
|
||||||
|
|
||||||
|
multilib = [
|
||||||
|
('^Everything$', {
|
||||||
|
'x86_64': ['devel', 'runtime'],
|
||||||
|
})
|
||||||
|
]
|
||||||
|
|
||||||
|
# These packages should never be multilib on any arch.
|
||||||
|
multilib_blacklist = {
|
||||||
|
'*': [
|
||||||
|
'kernel', 'kernel-PAE*', 'kernel*debug*', 'java-*', 'php*', 'mod_*', 'ghc-*'
|
||||||
|
],
|
||||||
|
}
|
||||||
|
|
||||||
|
# These should be multilib even if they don't match the rules defined above.
|
||||||
|
multilib_whitelist = {
|
||||||
|
'*': ['wine', '*-static'],
|
||||||
|
}
|
||||||
|
|
||||||
|
createiso_skip = [
|
||||||
|
# Keep binary ISOs for Server, but not source ones.
|
||||||
|
('^Server$', {'src': True}),
|
||||||
|
|
||||||
|
# Remove all other ISOs.
|
||||||
|
('^Everything$', {'*': True, 'src': True}),
|
||||||
|
('^Modular$', {'*': True, 'src': True}),
|
||||||
|
]
|
||||||
|
|
||||||
|
# Image name respecting Fedora's image naming policy
|
||||||
|
image_name_format = '%(release_short)s-%(variant)s-%(disc_type)s-%(arch)s-%(version)s-%(date)s%(type_suffix)s.%(respin)s.iso'
|
||||||
|
# Use the same format for volume id
|
||||||
|
image_volid_formats = [
|
||||||
|
'%(release_short)s-%(variant)s-%(disc_type)s-%(arch)s-%(version)s'
|
||||||
|
]
|
||||||
|
# Used by Pungi to replace 'Cloud' with 'C' (etc.) in ISO volume IDs.
|
||||||
|
# There is a hard 32-character limit on ISO volume IDs, so we use
|
||||||
|
# these to try and produce short enough but legible IDs. Note this is
|
||||||
|
# duplicated in Koji for live images, as livemedia-creator does not
|
||||||
|
# allow Pungi to tell it what volume ID to use. Note:
|
||||||
|
# https://fedoraproject.org/wiki/User:Adamwill/Draft_fedora_image_naming_policy
|
||||||
|
volume_id_substitutions = {
|
||||||
|
'Beta': 'B',
|
||||||
|
'Rawhide': 'rawh',
|
||||||
|
'Silverblue': 'SB',
|
||||||
|
'Cinnamon': 'Cinn',
|
||||||
|
'Cloud': 'C',
|
||||||
|
'Design_suite': 'Dsgn',
|
||||||
|
'Electronic_Lab': 'Elec',
|
||||||
|
'Everything': 'E',
|
||||||
|
'Scientific_KDE': 'SciK',
|
||||||
|
'Security': 'Sec',
|
||||||
|
'Server': 'S',
|
||||||
|
'Workstation': 'WS',
|
||||||
|
}
|
||||||
|
|
||||||
|
disc_types = {
|
||||||
|
'boot': 'netinst',
|
||||||
|
'live': 'Live',
|
||||||
|
}
|
||||||
|
|
||||||
|
translate_paths = [
|
||||||
|
('/mnt/koji/compose/', 'https://kojipkgs.fedoraproject.org/compose/'),
|
||||||
|
]
|
||||||
|
|
||||||
|
# These will be inherited by live_media, live_images and image_build
|
||||||
|
global_ksurl = 'git+https://pagure.io/fedora-kickstarts.git?#HEAD'
|
||||||
|
global_release = '!RELEASE_FROM_LABEL_DATE_TYPE_RESPIN'
|
||||||
|
global_version = 'Rawhide'
|
||||||
|
# live_images ignores this in favor of live_target
|
||||||
|
global_target = 'f32'
|
||||||
|
|
||||||
|
image_build = {
|
||||||
|
'^Container$': [
|
||||||
|
{
|
||||||
|
'image-build': {
|
||||||
|
'format': [('docker', 'tar.xz')],
|
||||||
|
'name': 'Fedora-Container-Base',
|
||||||
|
'kickstart': 'fedora-container-base.ks',
|
||||||
|
'distro': 'Fedora-22',
|
||||||
|
'disk_size': 5,
|
||||||
|
'arches': ['armhfp', 'aarch64', 'ppc64le', 's390x', 'x86_64'],
|
||||||
|
'repo': 'Everything',
|
||||||
|
'install_tree_from': 'Everything',
|
||||||
|
'subvariant': 'Container_Base',
|
||||||
|
'failable': ['*'],
|
||||||
|
},
|
||||||
|
'factory-parameters': {
|
||||||
|
'dockerversion': "1.10.1",
|
||||||
|
'docker_cmd': '[ "/bin/bash" ]',
|
||||||
|
'docker_env': '[ "DISTTAG=f32container", "FGC=f32", "container=oci" ]',
|
||||||
|
'docker_label': '{ "name": "fedora", "license": "MIT", "vendor": "Fedora Project", "version": "32"}',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}
|
||||||
|
|
||||||
|
live_media = {
|
||||||
|
'^Workstation$': [
|
||||||
|
{
|
||||||
|
'name': 'Fedora-Workstation-Live',
|
||||||
|
'kickstart': 'fedora-live-workstation.ks',
|
||||||
|
# Variants.xml also contains aarch64 and armhfp, but there
|
||||||
|
# should be no live media for those arches.
|
||||||
|
'arches': ['x86_64', 'ppc64le'],
|
||||||
|
'failable': ['ppc64le'],
|
||||||
|
# Take packages and install tree from Everything repo.
|
||||||
|
'repo': 'Everything',
|
||||||
|
'install_tree_from': 'Everything',
|
||||||
|
}
|
||||||
|
],
|
||||||
|
'^Spins': [
|
||||||
|
# There are multiple media for Spins variant. They use subvariant
|
||||||
|
# field so that they can be indentified in the metadata.
|
||||||
|
{
|
||||||
|
'name': 'Fedora-KDE-Live',
|
||||||
|
'kickstart': 'fedora-live-kde.ks',
|
||||||
|
'arches': ['x86_64'],
|
||||||
|
'repo': 'Everything',
|
||||||
|
'install_tree_from': 'Everything',
|
||||||
|
'subvariant': 'KDE'
|
||||||
|
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'name': 'Fedora-Xfce-Live',
|
||||||
|
'kickstart': 'fedora-live-xfce.ks',
|
||||||
|
'arches': ['x86_64'],
|
||||||
|
'failable': ['*'],
|
||||||
|
'repo': 'Everything',
|
||||||
|
'install_tree_from': 'Everything',
|
||||||
|
'subvariant': 'Xfce'
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}
|
||||||
|
|
||||||
|
failable_deliverables = [
|
||||||
|
# Installer and ISOs for server failing do not abort the compose.
|
||||||
|
('^Server$', {
|
||||||
|
'*': ['buildinstall', 'iso'],
|
||||||
|
}),
|
||||||
|
('^.*$', {
|
||||||
|
# Buildinstall is not blocking
|
||||||
|
'src': ['buildinstall'],
|
||||||
|
# Nothing on i386, ppc64le blocks the compose
|
||||||
|
'i386': ['buildinstall', 'iso'],
|
||||||
|
'ppc64le': ['buildinstall', 'iso'],
|
||||||
|
's390x': ['buildinstall', 'iso'],
|
||||||
|
})
|
||||||
|
]
|
||||||
|
|
||||||
|
live_target = 'f32'
|
||||||
|
live_images_no_rename = True
|
||||||
|
live_images = [
|
||||||
|
('^Workstation$', {
|
||||||
|
'armhfp': {
|
||||||
|
'kickstart': 'fedora-arm-workstation.ks',
|
||||||
|
'name': 'Fedora-Workstation-armhfp',
|
||||||
|
# Again workstation takes packages from Everything.
|
||||||
|
'repo': 'Everything',
|
||||||
|
'type': 'appliance',
|
||||||
|
'failable': True,
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
('^Server$', {
|
||||||
|
# But Server has its own repo.
|
||||||
|
'armhfp': {
|
||||||
|
'kickstart': 'fedora-arm-server.ks',
|
||||||
|
'name': 'Fedora-Server-armhfp',
|
||||||
|
'type': 'appliance',
|
||||||
|
'failable': True,
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
]
|
||||||
|
|
||||||
|
ostree = {
|
||||||
|
"^Silverblue$": {
|
||||||
|
"version": "!OSTREE_VERSION_FROM_LABEL_DATE_TYPE_RESPIN",
|
||||||
|
# To get config, clone master branch from this repo and take
|
||||||
|
# treefile from there.
|
||||||
|
"treefile": "fedora-silverblue.yaml",
|
||||||
|
"config_url": "https://pagure.io/workstation-ostree-config.git",
|
||||||
|
"config_branch": "master",
|
||||||
|
# Consume packages from Everything
|
||||||
|
"repo": "Everything",
|
||||||
|
# Don't create a reference in the ostree repo (signing automation does that).
|
||||||
|
"tag_ref": False,
|
||||||
|
# Don't use change detection in ostree.
|
||||||
|
"force_new_commit": True,
|
||||||
|
# This is the location for the repo where new commit will be
|
||||||
|
# created. Note that this is outside of the compose dir.
|
||||||
|
"ostree_repo": "/mnt/koji/compose/ostree/repo/",
|
||||||
|
"ostree_ref": "fedora/rawhide/${basearch}/silverblue",
|
||||||
|
"arches": ["x86_64", "ppc64le", "aarch64"],
|
||||||
|
"failable": ['*'],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ostree_installer = [
|
||||||
|
("^Silverblue$", {
|
||||||
|
"x86_64": {
|
||||||
|
"repo": "Everything",
|
||||||
|
"release": None,
|
||||||
|
"rootfs_size": "8",
|
||||||
|
# Take templates from this repository.
|
||||||
|
'template_repo': 'https://pagure.io/fedora-lorax-templates.git',
|
||||||
|
'template_branch': 'master',
|
||||||
|
# Use following templates.
|
||||||
|
"add_template": ["ostree-based-installer/lorax-configure-repo.tmpl",
|
||||||
|
"ostree-based-installer/lorax-embed-repo.tmpl",
|
||||||
|
"ostree-based-installer/lorax-embed-flatpaks.tmpl"],
|
||||||
|
# And add these variables for the templates.
|
||||||
|
"add_template_var": [
|
||||||
|
"ostree_install_repo=https://kojipkgs.fedoraproject.org/compose/ostree/repo/",
|
||||||
|
"ostree_update_repo=https://ostree.fedoraproject.org",
|
||||||
|
"ostree_osname=fedora",
|
||||||
|
"ostree_oskey=fedora-32-primary",
|
||||||
|
"ostree_contenturl=mirrorlist=https://ostree.fedoraproject.org/mirrorlist",
|
||||||
|
"ostree_install_ref=fedora/rawhide/x86_64/silverblue",
|
||||||
|
"ostree_update_ref=fedora/rawhide/x86_64/silverblue",
|
||||||
|
"flatpak_remote_name=fedora",
|
||||||
|
"flatpak_remote_url=oci+https://registry.fedoraproject.org",
|
||||||
|
"flatpak_remote_refs=runtime/org.fedoraproject.Platform/x86_64/f30 app/org.gnome.Baobab/x86_64/stable",
|
||||||
|
],
|
||||||
|
'failable': ['*'],
|
||||||
|
},
|
||||||
|
})
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
RCM Tools compose
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
This is a small compose used to deliver packages to Red Hat internal users. The
|
||||||
|
configuration is split into two files.
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
# rcmtools-common.conf
|
||||||
|
|
||||||
|
release_name = "RCM Tools"
|
||||||
|
release_short = "RCMTOOLS"
|
||||||
|
release_version = "2.0"
|
||||||
|
release_type = "updates"
|
||||||
|
release_is_layered = True
|
||||||
|
createrepo_c = True
|
||||||
|
createrepo_checksum = "sha256"
|
||||||
|
|
||||||
|
# PKGSET
|
||||||
|
pkgset_source = "koji"
|
||||||
|
koji_profile = "brew"
|
||||||
|
pkgset_koji_inherit = True
|
||||||
|
|
||||||
|
|
||||||
|
# GENERAL SETTINGS
|
||||||
|
bootable = False
|
||||||
|
comps_file = "rcmtools-comps.xml"
|
||||||
|
variants_file = "rcmtools-variants.xml"
|
||||||
|
sigkeys = ["3A3A33A3"]
|
||||||
|
|
||||||
|
|
||||||
|
# RUNROOT settings
|
||||||
|
runroot = False
|
||||||
|
|
||||||
|
|
||||||
|
# GATHER
|
||||||
|
gather_method = "deps"
|
||||||
|
check_deps = True
|
||||||
|
|
||||||
|
additional_packages = [
|
||||||
|
('.*', {
|
||||||
|
'*': ['puddle', 'rcm-nexus'],
|
||||||
|
}
|
||||||
|
),
|
||||||
|
]
|
||||||
|
|
||||||
|
# Set repoclosure_strictness to fatal to avoid installation dependency
|
||||||
|
# issues in production composes
|
||||||
|
repoclosure_strictness = [
|
||||||
|
("^.*$", {
|
||||||
|
"*": "fatal"
|
||||||
|
})
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
Configuration specific for different base products is split into separate files.
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
# rcmtools-common.conf
|
||||||
|
from rcmtools-common import *
|
||||||
|
|
||||||
|
# BASE PRODUCT
|
||||||
|
base_product_name = "Red Hat Enterprise Linux"
|
||||||
|
base_product_short = "RHEL"
|
||||||
|
base_product_version = "7"
|
||||||
|
|
||||||
|
# PKGSET
|
||||||
|
pkgset_koji_tag = "rcmtools-rhel-7-compose"
|
||||||
|
|
||||||
|
# remove i386 arch on rhel7
|
||||||
|
tree_arches = ["aarch64", "ppc64le", "s390x", "x86_64"]
|
||||||
|
|
||||||
|
check_deps = False
|
||||||
|
|
||||||
|
# Packages in these repos are available to satisfy dependencies inside the
|
||||||
|
# compose, but will not be pulled in.
|
||||||
|
gather_lookaside_repos = [
|
||||||
|
("^Client|Client-optional$", {
|
||||||
|
"x86_64": [
|
||||||
|
"http://example.redhat.com/rhel/7/Client/x86_64/os/",
|
||||||
|
"http://example.redhat.com/rhel/7/Client/x86_64/optional/os/",
|
||||||
|
],
|
||||||
|
}),
|
||||||
|
("^Workstation|Workstation-optional$", {
|
||||||
|
"x86_64": [
|
||||||
|
"http://example.redhat.com/rhel/7/Workstation/x86_64/os/",
|
||||||
|
"http://example.redhat.com/rhel/7/Workstation/x86_64/optional/os/",
|
||||||
|
],
|
||||||
|
}),
|
||||||
|
("^Server|Server-optional$", {
|
||||||
|
"aarch64": [
|
||||||
|
"http://example.redhat.com/rhel/7/Server/aarch64/os/",
|
||||||
|
"http://example.redhat.com/rhel/7/Server/aarch64/optional/os/",
|
||||||
|
],
|
||||||
|
"ppc64": [
|
||||||
|
"http://example.redhat.com/rhel/7/Server/ppc64/os/",
|
||||||
|
"http://example.redhat.com/rhel/7/Server/ppc64/optional/os/",
|
||||||
|
],
|
||||||
|
"ppc64le": [
|
||||||
|
"http://example.redhat.com/rhel/7/Server/ppc64le/os/",
|
||||||
|
"http://example.redhat.com/rhel/7/Server/ppc64le/optional/os/",
|
||||||
|
],
|
||||||
|
"s390x": [
|
||||||
|
"http://example.redhat.com/rhel/7/Server/s390x/os/",
|
||||||
|
"http://example.redhat.com/rhel/7/Server/s390x/optional/os/",
|
||||||
|
],
|
||||||
|
"x86_64": [
|
||||||
|
"http://example.redhat.com/rhel/7/Server/x86_64/os/",
|
||||||
|
"http://example.redhat.com/rhel/7/Server/x86_64/optional/os/",
|
||||||
|
],
|
||||||
|
})
|
||||||
|
]
|
@ -15,6 +15,7 @@ Contents:
|
|||||||
phases
|
phases
|
||||||
format
|
format
|
||||||
configuration
|
configuration
|
||||||
|
examples
|
||||||
scm_support
|
scm_support
|
||||||
messaging
|
messaging
|
||||||
gathering
|
gathering
|
||||||
|
Loading…
Reference in New Issue
Block a user