Provided by: debootstick_2.8_all bug

NAME

       debootstick - Generate a bootable image from a Debian-based chroot environment

SYNOPSIS

       debootstick [options] SOURCE DEST

DESCRIPTION

       debootstick generates a bootable image (at DEST) from a Debian-based chroot environment (at SOURCE).
       The output image generated at DEST should then be copied to a USB stick, disk or SD card.

       debootstick can currently generate bootable images for:
       - Standard PC systems (32 or 64bits)
       - Raspberry Pi boards
       This  target  system  is  automatically  selected  given  the SOURCE chroot environment (Debian/Ubuntu or
       Raspbian-based).

       Most popular options for generating the SOURCE directory are:
       - exporting the content of a docker container
       - using dedicated tools such as debootstrap(8) or qemu-debootstrap(1)
       See section CHROOT ENVIRONMENTS below.

       The embedded system is:
       - ready to be used (no installation step)
       - viable in the long-term, fully upgradable (kernel, bootloader included)
       - compatible with BIOS and UEFI systems (PC), or Raspberry Pi Boards.

       debootstick can also generate installer media (for PCs). See option --system-type below.

OPTIONS

       debootstick follows the usual GNU command line syntax, with long options starting with two dashes  (`-').
       A summary of options is included below.

       -h, --help
              Show summary of options.

       -v, --version
              Show version of program.

       --help-os-support
              Describe which chroot environments are supported.

       --system-type [live|installer]
              Specify  which  kind  of  system  is  targeted.  The default is live.  When booting a system where
              installer was selected, the system will try to migrate to a larger device on  first  startup.   If
              live  was  selected,  or  if  no  such option was specified, no migration will occur.  See section
              INSTALLER MEDIA below.

       --kernel-package PACKAGE_NAME
              Specify the kernel that should be installed. Without  this  option,  debootstick  will  install  a
              default one (depending on the embedded distribution).

       --config-hostname HOSTNAME
              Specify the hostname the embedded system will have.

       --config-kernel-bootargs BOOTARGS
              Specify  boot  arguments  to  be  added/removed from the kernel cmdline.  Use a plus sign to get a
              bootarg added and a minus sign to have it removed from the existing bootloader configuration.  For
              example, --config-kernel-bootargs "+console=ttyS0 -rootdelay" will add console=ttyS0 to the kernel
              cmdline, and remove any parameter matching rootdelay=<value> or just rootdelay.  When no  plus  or
              minus sign is specified, the bootarg is added (like plus).  An alternative to using this option is
              to have the bootloader installed and customized before you call debootstick.

       --config-root-password-ask
              Prompt for the root password of the embedded system and set it accordingly.

       --config-root-password-none
              Remove the root password of the embedded system (root login will not prompt any password).

       --config-root-password-first-boot
              Ask for the root password when the system will be booted for the first time.

       --config-grub-on-serial-line
              Update grub configuration to show boot menu on serial line. (This is obviously PC-specific.)

       --disk-layout DISK_LAYOUT_FILE
              Specify an alternate disk layout configuration file. See section DISK LAYOUTS below.

       --run-on-first-boot FIRST_BOOT_SCRIPT_FILE
              Let debootstick run the specified custom script (or other kind of executable) on first boot, after
              OS  resizing  or  migration  is completed.  The path specified must be relative to the root of the
              chroot environment.

       --sector-size SECTOR_SIZE
              Specify an alternate sector size (default is 512).  For instance, to build an image that  will  be
              flashed on a 4Kn disk, use --sector-size 4096.
              See section DISK SECTOR SIZE below.

EXAMPLES

       The most common workflow is the following.

       1- Generate a chroot environment:
       debootstrap --variant=minbase buster /tmp/buster_tree

       2- (Optionally) customize it:
       chroot /tmp/buster_tree; [...]; exit

       3- Generate the bootable image:
       debootstick --config-root-password-ask /tmp/buster_tree /tmp/img.dd
       Enter root password:
       Enter root password again:
       OK
       [...]

       4- Test it with kvm.
       cp /tmp/img.dd /tmp/img.dd-test    # let's work on a copy, our test is destructive
       truncate -s 2G /tmp/img.dd-test    # simulate a copy on a 2G-large USB stick
       kvm -m 2048 -hda /tmp/img.dd-test  # the test itself (BIOS mode)

       5- Copy the boot image to a USB stick or disk.
       dd bs=10M if=/tmp/img.dd of=/dev/your-device

       The USB device may now be booted on any BIOS or UEFI system.

CHROOT ENVIRONMENTS

       An example of chroot environment generation for a PC system is given in the previous section.

       In order to generate a chroot environment for a Raspberry Pi, you can use qemu-debootstrap(1):
       qemu-debootstrap       --no-check-gpg       --arch=armhf       --variant=minbase       buster      rpi-fs
       http://mirrordirector.raspbian.org/raspbian

       Exporting the OS files from a virtual machine or a docker container  is  another  option  to  generate  a
       chroot  environment.   The  added  benefit  of  this  approach  is that a virtualized environment is very
       convenient for the OS customization phase, before calling debootstick.

TARGET SYSTEM ARCHITECTURES

       debootstick expects a chroot environment built for amd64 or i386 systems, or for Raspberry Pi boards.  Of
       course,  the  resulting  image  will reflect this initial architecture, and thus it should be booted on a
       compatible system.

INSTALLER MEDIA

       When first booting a system built with the --system-type installer option, it will look for a larger disk
       and  move  to  that  disk.   This  operation  does  not require a reboot. Once done, the system will just
       continue its bootup procedure (and the initial device can be removed).

       Notes:
       - CAUTION: Any data on the target disk will be lost!
       - The system is moved, not copied. Thus the initial device cannot be used anymore  after  the  migration,
       unless you copy an image on it again, of course.
       -  This option is not available for Raspberry Pi boards.  It would make little sense anyway, since the SD
       card is usually the only bootable media available on this kind of board.

UEFI BOOTING

       It is also possible to test the UEFI boot with kvm, if you have the ovmf  package  installed,  by  adding
       -bios /path/to/OVMF.fd to the kvm command line.

DISK LAYOUTS

       It is possible to modify the disk layout of the system debootstick generates.

       If  option  --disk-layout  is  not specified, a default layout file is used, and the path of this file is
       printed.
       The preferred way to write a new layout file is to copy this default file, modify it, and then add option
       --disk-layout <modified-layout>.
       An example of a modification could be to set /var on a different partition or dedicated LVM volume.

       Notes:
       - Not all modifications are allowed. debootstick will print an error message if needed.
       - Currently debootstick only handles fat and ext4 filesystems.

       About the size of a partition or lvm volume:
       -  auto  means debootstick will reserve enough space for this volume, with a little margin. For instance,
       on a /boot partition with fat filesystem, it will estimate the size needed for the files stored there and
       size the partition accordingly.
       -  <xx>[G|M]  (e.g.  1G  or  50M)  means  debootstick  should allocate exactly the specified size to this
       partition/volume. Use this preferably on LVM volumes or on the last disk partition: since  previous  disk
       partitions  cannot  be  resized,  debootstick  has  to  reserve  the  space for them on the disk image it
       generates, which can make it large.
       - <xx>% (e.g. 10%)  means  debootstick  should  allocate  the  given  percentage  of  the  disk  to  this
       partition/volume.
       - max means debootstick should allocate any remaining free space to this partition/volume.

       Keep  in  mind  that  debootstick  is  supposed to generate a minimal image, and, at this time, it has no
       knowledge about the size of the device where the image will be copied.  Using max and  <xx>%  on  an  lvm
       volume  and  on  last  partition allows one to ensure an appropriate disk layout, when the OS will expand
       itself over the device (or migrate), on first boot.

       If LVM is used, it is possible to set a custom volume group  name  by  using  keyword  lvm_vg_name.   For
       instance,  one could specify lvm_vg_name "MYVG" (quotes are optional).  If not specified, or when special
       value auto is given instead of the group name, debootstick generates a random name DBSTCK_<hex-value>.
       Note that on first boot, even if a volume group name was specified, the system will first use the  random
       name  DBSTCK_<hex-value>,  and then rename it at the end of the bootup procedure.  This allows the system
       to boot properly even if the target name conflicts with a volume group already  present  on  a  secondary
       disk.

DISK SECTOR SIZE

       If the image should be flashed on a disk with non-default logical sector size (default is 512 bytes), one
       may use option --sector-size <value> to change it.

       The value of option --sector-size should match the logical sector size of the  disk  the  image  will  be
       flashed  on. Usually, this disk is a removable device with a logical sector size of 512 bytes. Thus, in a
       vast majority of cases debootstick should generate a compatible image with its default option value.

       When using the installer mode, the fact the target disk (i.e. the disk the OS will  finally  migrate  to)
       has a different sector size does not mean the image sector size should be changed.

DESIGN NOTES

       Many Live distributions propose a highly compressed system based on a squashfs image.  They handle writes
       using an overlay based on a filesystem union.  While this allows the system  to  remain  compact  in  the
       first times, this also has disavantages:
       -  Some important files remain read-only and cannot be upgraded (that is the case of the linux kernel and
       the bootloader) which quickly leads to security issues or upgrade problems.
       - Storing modified files in an overlay and never releasing the room needed for the original  versions  in
       the squashfs image is counter-productive in the long term.
       One  of  the objectives debootstick achieves is to provide a viable long-term live system, therefore this
       kind of setup has been discarded.

AUTHORS

       Etienne Duble (etienne.duble@imag.fr) and contributors.

SEE ALSO

       debootstrap(8), qemu-debootstrap(1), kvm(1).

                                                November 2, 2020                                  DEBOOTSTICK(8)