SYNOPSIS
debirf <subcommand> [options] [args]DESCRIPTION
debirf (DEBian on Initial Ram Filesystem) is a set of tools designed to create and prepare a kernel and initial ram filesystem that can run a full-blown Debian environment entirely from RAM.
debirf has various subcommands (see SUBCOMMANDS) which act on a specified debirf profile (see PROFILES).
The debirf system is outlined at:
EXAMPLES
Make a stock debirf rescue image using the default settings:
$ tar xzf /usr/share/doc/debirf/example-profiles/rescue.tgz $ debirf make rescue
Make a debirf rescue image, specifying the mirror and a local HTTP proxy:
$ tar xzf /usr/share/doc/debirf/example-profiles/rescue.tgz $ DEBIRF_MIRROR=http://ftp.debian.org/debian http_proxy=http://127.0.0.1:3128/ debirf make rescue
SUBCOMMANDS
debirf takes various subcommands:- make [options] PROFILE
- Create a debirf system based on profile PROFILE. This will create the root for the profile, run all modules on the root, and then generate the kernel image (see KERNEL) and debirf initramfs. This subcommand takes various options (see OPTIONS).
- enter PROFILE
- Chroot into root of profile PROFILE, with full profile environment.
- makeiso PROFILE
- Create a bootable CD-ROM image from the kernel and initramfs in PROFILE. This requires a bootloader to be available. If grub-mkrescue (in the grub-common package on debian) is available, it will be used. Otherwise, isolinux is used if it is available. You may use the DEBIRF_ISO_BOOTLOADER environment variable to specify a preference manually (see below).
- help
- Output a brief usage summary.
OPTIONS (for make subcommand only)
- -c, --check-vars
- check variables before make
- -n, --new
- create new root, even if old one exists
- -o, --overwrite
- debootstrap on top of old root if it exists
- -s, --skip
- skip debootstrap step altogether if old root exists
- -r, --root-build
- use real chroot to build instead of fakechroot (requires superuser privileges or CAP_SYS_CHROOT)
- -w, --no-warning
- skip superuser warning
- -i, --initrd-only
- remake initramfs from existing root (skip debootstrap and module stages)
- -k, --kernel-deb=KERNEL
- install KERNEL .deb, instead of default kernel
PROFILES
A debirf profile is a directory containing a debirf.conf config file and a modules sub-directory (see MODULES).
PACKAGE INCLUDES/EXCLUDES
If the profile directory includes a 'packages' file, it is interpreted as a list of packages to include/exclude during the debootstrap stage. Packages should be specified one per line, with a '+' prefix to indicate inclusion during debootstrap, or a '-' prefix to indicate exclusion.
MODULES
Modules are used to configure the debirf system, and can be used to extend the capabilities of debirf. Modules are bash shell scripts that are executed in alpha-numeric order by run-parts in a chroot in the debirf root during the module stage of the debirf build. The module stage is right after the debirf debootstrap stage, and right before the initramfs archive is created. All shell variables beginning with "DEBIRF_", including those defined in the debirf.conf file, are available to the modules.
Modules may specify packages to be included/excluded during the debootstrap stage with special '#DEBIRF_PACKAGE>' comments anywhere in the module. Lines beginning with '#DEBIRF_PACKAGE>+' specify packages to include, and lines beginning with '#DEBIRF_PACKAGE>-' indicate packages to exclude. Only one package should be specified per comment line (no spaces). So for instance, the lines:
#DEBIRF_PACKAGE>+emacs #DEBIRF_PACKAGE>+ed #DEBIRF_PACKAGE>-nanowould include the packages emacs and ed, and would exclude the package nano.
NOTE: Some modules are more important to the proper functioning of debirf than others, and the ordering of modules is important. Some modules may depend on certain other modules having already been, or not yet been, run. For instance, the module that cleans the debirf apt cache ("z1_clean_root") should be the last module run at the end of the module stage.
KERNEL
The debirf "install-kernel" module will try to pick the most up-to-date kernel for the suite you are installing (versions 2.6 only), with the arch determined by the kernel running on the host build system.
FUNCTIONS
A set of pre-defined bash shell functions are available to the modules to fasciliate configuring the debirf system:
- debirf_exec <command>
- Execute <command> within debirf root (DEBIRF_ROOT) with chroot.
- msg <message>
- Output a message to standard out during the build process.
- failure <message> <exit-code>
- Cause debirf script to fail with <exit-code>, and <message> to stderr.
- debirf_info_sh <message>
- Write one line of sh code to the debirf.info file on the debirf root.
- debirf_info_comment <message>
- Write one line of comment to the debirf.info file on the debirf root.
ENVIRONMENT
The following environment variables are used by debirf:
- DEBIRF_LABEL
- debirf label (default: debirf)
- DEBIRF_BUILDD
- where to build the debirf (default: ./)
- DEBIRF_ARCH
- architecture to build (default is the architecture of the build machine)
- DEBIRF_SUITE
- suite to build from (default determined from lsb_release, otherwise "sid")
- DEBIRF_DISTRO
- distro for suite (default determined from lsb_release, otherwise "debian")
- DEBIRF_MIRROR
- mirror to pull suite (default determined by DEBIRF_DISTRO)
- DEBIRF_KEYRING
- keyring to verify debootstrap (default determined by DEBIRF_DISTRO)
- DEBIRF_KERNEL_FLAVOR
- the flavor of kernel debirf should install. Supply everything from a typical debian package name after the version number. e.g. 486, vserver-686-bigmem, openvz-amd64. (default chosen based on currently-running kernel)
- DEBIRF_ISO_BOOTLOADER
- whether to use "grub" or "isolinux" as the El Torito bootloader for debirf makeiso. if not specified, "grub" is the default.
FILES
- $DEBIRF_PROFILE/debirf.conf
- Debirf profile configuration file. Contains values for the various debirf environment variables (see ENVIRONMENT). Variables specified in the debirf.conf override those specified on the command line.
- $DEBIRF_ROOT/etc/debirf/debirf.info
- File that stores various information about the debirf build. This is a bash-sourceable file.
AUTHOR
Written by Jameson Rollins and Daniel Kahn Gillmor.BUGS
Debirf does not work as a non-privileged user across different versions of libc. In particular, this means that you probably won't be able to build an image from a different version of the operating system than you're using without building as root. (see http://bugs.debian.org/650242)Please report bugs in debirf via the debian BTS: http://bugs.debian.org/
COPYRIGHT
Copyright © 2007-2011 Jameson Rollins and Daniel Kahn GillmorThis is free software. You may redistribute copies of it under the terms of the GNU General Public License <http://www.gnu.org/licenses/gpl.html>. There is NO WARRANTY, to the extent permitted by law.