(→Storage: update commit link) |
(update for Fedora 24 changes) |
||
Line 16: | Line 16: | ||
==Storage== | ==Storage== | ||
When a Live CD or Live DVD (a LiveOS image on read-only disc media) is booted, '''temporary storage''' is prepared for the system in RAM on each boot by [http://git.kernel.org/?p=boot/dracut/dracut.git;a=blob;f=modules.d/90dmsquash-live/dmsquash-live-root.sh;hb=HEAD /sbin/dmsquash-live-root] in | When a Live CD or Live DVD (a LiveOS image on read-only disc media) is booted, '''temporary storage''' is prepared for the system in RAM on each boot by [http://git.kernel.org/?p=boot/dracut/dracut.git;a=blob;f=modules.d/90dmsquash-live/dmsquash-live-root.sh;hb=HEAD /sbin/dmsquash-live-root] in initrd.img, the initial ram disk filesystem. By default, a 0.5 GiB, in-memory, copy-on-write, system overlay in a [[wikipedia:Sparse file|sparse file]] is prepared (see [[#File Systems|File Systems]] below). The {{Code|rd.live.overlay.size}} kernel command line option may be used to set a different, temporary, overlay size. | ||
When the {{Code|rd.live.overlay}} kernel command line option is provided on boot, such as with a Live USB device, the ''dmsquash-live-root.sh'' script will search for a persistent overlay file to use for storage of root filesystem changes. See [https://github.com/haraldh/dracut/blob/master/dracut.cmdline.7.asc#booting-live-images Booting live images] in the ''dracut'' package. | When the {{Code|rd.live.overlay}} kernel command line option is provided on boot, such as with a Live USB device, the ''dmsquash-live-root.sh'' script will search for a persistent overlay file to use for storage of root filesystem changes. See [https://github.com/haraldh/dracut/blob/master/dracut.cmdline.7.asc#booting-live-images Booting live images] in the ''dracut'' package. | ||
With Fedora 24 (kernel 4.3+), if the overlay is exhausted, the overlay will enter a 'Overflow' state and the root file system will continue to operate in a read-only mode. See [[LiveOS image/overlay]] for instructions on how one may then either enlarge or merge the overlay. | |||
''' | :'''Note:''' In systems built before Fedora 24, should the overlay storage space, whether temporary or persistent, be totally consumed, the filesystem will be flagged 'Invalid' and the system will crash with Input/output or Bus errors. If such a crash does occur while using temporary storage space for the overlay, a simple reboot will rectify the situation. With persistent storage the situation is more dire and will require appending {{Code|rd.live.overlay.reset}} (formerly, {{Code|reset_overlay}}) to the kernel command line on boot-up. This will vacate all changes to the root file system (though a persistent home filesystem, if used, will be unaffected). In either case, achieving a reboot will require a hard reset, since attempting a software initiated reboot on the Invalid filesystem will fail with more Input/output or Bus errors. See [[#Overlay allocation status]] for a way to monitor overlay consumption. | ||
===Operating system file systems=== | ===Operating system file systems=== | ||
Live Operating System, '''LiveOS''', file systems are found within disk image '''.img''' files. | Live Operating System, '''LiveOS''', file systems are found within disk image '''.img''' files. | ||
If one mounts a Fedora-Live | If one mounts a Fedora-Workstation-Live.iso file or Live CD, the file system will list folders such as the following: | ||
/EFI | /EFI | ||
/images | |||
/isolinux | /isolinux | ||
/LiveOS | /LiveOS | ||
|- squashfs.img | |- squashfs.img | ||
(Systems before Fedora 24 also had these files | |||
|- livecd-iso-to-disk - a Bash script for installing the LiveOS image onto a USB device | |||
|- osmin.img - a minimized OS image formerly used to aid installation to a hard disk | |||
Mounting the squashfs.img file and listing its | |||
The squashfs.img is a [[wikipedia:SquashFS|SquashFS]] compressed, read-only, file system holding the Fedora operating system root file system inside another LiveOS folder containing a rootfs.img file. | |||
Mounting the squashfs.img file and listing its file system will show this hierarchy: | |||
/LiveOS | /LiveOS | ||
|- | |- rootfs.img (This contains a filesystem of type ext4. Before F-24 it was named ext3fs.img.) | ||
Mounting the | Mounting the rootfs.img file will finally reveal the Fedora operating system root file system. | ||
Here is a summary of the whole structure: | Here is a summary of the whole structure: | ||
'''Fedora-Live | '''Fedora-Workstation-Live.iso''' | ||
''!(mount)'' | ''!(mount)'' | ||
/EFI | /EFI | ||
/image | |||
/isolinux | /isolinux | ||
/LiveOS | /LiveOS | ||
|- '''squashfs.img''' | |- '''squashfs.img''' | ||
''!(mount)'' | ''!(mount)'' | ||
/LiveOS | /LiveOS | ||
|- ''' | |- '''rootfs.img''' | ||
''!(mount)'' | ''!(mount)'' | ||
/bin -> usr/bin | /bin -> usr/bin | ||
/boot | /boot | ||
Line 64: | Line 62: | ||
/home | /home | ||
/lib -> usr/lib | /lib -> usr/lib | ||
/lib64 -> usr/lib64 | |||
/lost+found | /lost+found | ||
/media | /media | ||
Line 80: | Line 79: | ||
When the LiveOS image is loaded onto a USB or SD disk, the {{Code|isolinux}} folder is copied into a {{Code|syslinux}} folder. | When the LiveOS image is loaded onto a USB or SD disk, the {{Code|isolinux}} folder is copied into a {{Code|syslinux}} folder. | ||
If persistence is requested with the {{Code|--overlay-size-mb NNN}} option, a Device-mapper overlay file for the root file system is created in {{Code|LiveOS}}. | If persistence is requested with the {{Code|--overlay-size-mb NNN}} option, a Device-mapper overlay file for the root file system is created in {{Code|/LiveOS}}. | ||
If a separate home file system is requested with the {{Code|--home-size-mb NNN}} option, an ext4 formatted {{Code|'''home.img'''}} file system is created. | If a separate home file system is requested with the {{Code|--home-size-mb NNN}} option, an ext4 formatted {{Code|'''home.img'''}} file system is created. | ||
The structure is then as follows: | The structure is then as follows: | ||
'''Fedora-Live | '''Fedora-Workstation-Live USB/SD device''' | ||
''!(mounted on /run/initramfs/live)'' (Before Fedora 17 the mount point is /mnt/live in the root file system.) | ''!(mounted on /run/initramfs/live)'' (Before Fedora 17 the mount point is /mnt/live in the root file system.) | ||
/syslinux | /syslinux | ||
Line 99: | Line 98: | ||
|- livecd-iso-to-disk | |- livecd-iso-to-disk | ||
|- '''overlay-NAME-XXXX-XXXX''' (Where NAME is the device partition name and XXXX are hex numerals.) | |- '''overlay-NAME-XXXX-XXXX''' (Where NAME is the device partition name and XXXX are hex numerals.) | ||
|- '''squashfs.img''' | |- '''squashfs.img''' | ||
''!(mount)'' (At boot up by the /usr/sbin/dmsquash-live-root.sh script in the initramfs.) | ''!(mount)'' (At boot up by the /usr/sbin/dmsquash-live-root.sh script in the initramfs.) | ||
/LiveOS | /LiveOS | ||
|- ''' | |- '''rootfs.img''' | ||
''!(mounted on '/')'' (This occurs during boot up by the dmsquash-live-root.sh script.) | ''!(mounted on '/')'' (This occurs during boot up by the dmsquash-live-root.sh script.) | ||
/bin -> usr/bin | /bin -> usr/bin | ||
Line 111: | Line 109: | ||
/home (If there is a '''home.img''', then this is its mount point directory.) | /home (If there is a '''home.img''', then this is its mount point directory.) | ||
If the {{Code|--skipcompress}} option is used during loading with {{Code|livecd-iso-to-disk}}, the '''squashfs.img''' | If the {{Code|--skipcompress}} option is used during loading with {{Code|livecd-iso-to-disk}}, the '''squashfs.img''' compressed image will be expanded. The structure is then as follows: | ||
'''Fedora-Live | '''Fedora-Workstation-Live USB/SD device''' | ||
''!(mounted on /run/initramfs/live)'' | ''!(mounted on /run/initramfs/live)'' | ||
/syslinux | /syslinux | ||
Line 122: | Line 120: | ||
|- livecd-iso-to-disk | |- livecd-iso-to-disk | ||
|- '''overlay-NAME-XXXX-XXXX''' | |- '''overlay-NAME-XXXX-XXXX''' | ||
|- '''rootfs.img''' | |||
|- ''' | |||
''!(mounted on '/')'' | ''!(mounted on '/')'' | ||
/bin -> usr/bin | /bin -> usr/bin | ||
Line 136: | Line 133: | ||
The Fedora LiveOS system allows for persistent storage in 3 locations: | The Fedora LiveOS system allows for persistent storage in 3 locations: | ||
# An all-purpose, persistent overlay-based file space that saves all updates and changes to the root LiveOS filesystem. | # An all-purpose, persistent overlay-based file space that saves all updates and changes to the root LiveOS filesystem. This storage '''space is limited''' by its allocate-once, fixed-sized design, and deserves some caution (see [[#File Systems|File Systems]] below). | ||
# Persistent home | # Persistent home filesystem - a re-writable, re-sizable (with difficulty), uncompressed, optionally-encryptable, file space for anything that goes in the user's /home/ folder. A persistent home filesystem is an option that may be selected at the time of installation of the LiveOS image (although with some effort, one could manually create a {{Code|home.img}} filesystem in {{Code|/LiveOS/}} and move the {{Code|/home/}} folder to it). This installation option is only available through the script, '[[livecd-iso-to-disk]]'. The Windows and Fedora 'Fedora Media Writer/Live USB Creator' installers do not provide this option at present. | ||
# Host device file space - this is the USB stick or SD card file system that is outside of the LiveOS file tree, but which is accessible through the {{Code|/run/initramfs/live}} or {{Code|/mnt/live}} (before Fedora 17) mount point of a booted LiveOS installation. There, one finds the boot configuration files and anything else one had on the device before loading the LiveOS image. One may save files here without consuming the other, limited file spaces. (This file space is limited only by the device capacity). | # Host device file space - this is the underlying USB stick or SD card file system that is outside of the LiveOS file tree, but which is accessible through the {{Code|/run/initramfs/live}} or {{Code|/mnt/live}} (before Fedora 17) mount point of a booted LiveOS installation. There, one finds the boot configuration files and anything else one had on the device before loading the LiveOS image. One may save files here without consuming the other, limited file spaces. (This file space is limited only by the device capacity). | ||
/run/initramfs/live | /run/initramfs/live | ||
/LiveOS | /LiveOS | ||
Line 144: | Line 141: | ||
|- livecd-iso-to-disk | |- livecd-iso-to-disk | ||
|- overlay-NAME-XXXX-XXXX | |- overlay-NAME-XXXX-XXXX | ||
|- squashfs.img | |- squashfs.img | ||
/syslinux | /syslinux | ||
Line 153: | Line 149: | ||
===Home filesystem=== | ===Home filesystem=== | ||
One may find many advantages to installing the LiveOS, with a persistent, home folder (using the --home-size-mb | One may find many advantages to installing the LiveOS, with a persistent, home folder (using the {{Code|--home-size-mb NNN}} option), which will hold all the user files and documents one wishes and, perhaps later, throw away—all without consuming the overlay that can be consumed very quickly. | ||
===Device filesystem=== | ===Device filesystem=== | ||
Line 159: | Line 155: | ||
===Installation options=== | ===Installation options=== | ||
Fedora | Fedora 24 Live Workstation may be installed on a 2 GB USB device using the following options with '''[[livecd-iso-to-disk]]''' (on a single, terminal or console command line, even though the wiki may wrap the following text to accommodate your browser window size): | ||
:{{Code|./livecd-iso-to-disk --reset-mbr --overlay-size-mb ''' | :{{Code|./livecd-iso-to-disk --reset-mbr --overlay-size-mb '''300''' --home-size-mb '''200''' --unencrypted-home /path/to/source/iso/or/device /dev/sd'''?'''1}} | ||
:: where '{{Code|'''?'''}}' in the final parameter represents the target bootable device node, such as {{Code|sd'''b'''1}} or {{Code|sd'''c'''1}}, etc. | :: where '{{Code|'''?'''}}' in the final parameter represents the target bootable device node, such as {{Code|sd'''b'''1}} or {{Code|sd'''c'''1}}, etc. | ||
The above configuration would allow space for the home folder, the operating system, and a | The above configuration would allow space for the home folder, the operating system, and a minimal amount on the device root. | ||
But with a larger capacity device, one may allocate the resources to suit the anticipated use, as described above. | But with a larger capacity device, one may allocate the resources to suit the anticipated use, as described above. | ||
Line 171: | Line 167: | ||
==File Systems== | ==File Systems== | ||
{{admon/note|Take note:|It is important to realize that because the LiveOS root filesystem normally resides in a compressed SquashFS image, the standard estimates of free disc space, such as those reported by {{Code|df}} and graphical file managers, will report '''"apparent" file space''' (as if the filesystem were not compressed), thus, such estimates are usually '''vast overestimates of the actual free space''' physically available to the root filesystem. The embedded ext3fs.img filesystem partition is often sized to just fit the distributed operating system at the time of its creation. | {{admon/note|Take note:|It is important to realize that because the LiveOS root filesystem normally resides in a compressed SquashFS image, the standard estimates of free disc space, such as those reported by {{Code|df}} and graphical file managers, will report '''"apparent" file space''' (as if the filesystem were not compressed), thus, such estimates are usually '''vast overestimates of the actual free space''' physically available to the root filesystem. The embedded ext3fs.img filesystem partition is often sized to just fit the distributed operating system at the time of its creation. | ||
: For example, the Fedora- | : For example, the Fedora-Workstation-Live-x86_64-24-1.2.iso contains an apparent 6.3 GiB ext4 root filesystem that has been sparsed and compressed into under 1.5 GiB of actual disc space in the .iso file (or on a LiveOS installed device file system). {{Code|df -h}} on an untouched mounting of the root filesystem will report that 4.0G is used and 2.3G is available space out of a total size of 6.3G. | ||
The actually available and allocated physical disc space for the root filesystem is determined by the size of the ''device-mapper'' overlay file and can only be queried by the {{Code|dmsetup status}} command (see below). | The actually available and allocated physical disc space for the root filesystem is determined by the size of the ''device-mapper'' overlay file and can only be queried by the {{Code|dmsetup status}} command (see below). | ||
: For example, one may add, and then delete, a large file in the root filesystem and see (the apparent virtual) used space go up, and then down, when checking with {{Code|df}}, but the {{Code|dmsetup status live-rw}} allocation report will only ever show an increase—even though allocated overlay sectors are available for reuse if an added file has been deleted (see discussion below).}} | : For example, one may add, and then delete, a large file in the root filesystem and see (the apparent virtual) used space go up, and then down, when checking with {{Code|df}}, but the {{Code|dmsetup status live-rw}} allocation report will only ever show an increase—even though allocated overlay sectors are available for reuse if an added file has been deleted (see discussion below).}} | ||
Fedora LiveOS uses the [[wikipedia:Device mapper|Device-mapper]] service of the Linux kernel to manage the file stores on the device. This is the same service that is used by [[wikipedia:Logical Volume Manager (Linux)|Logical Volume Manager]] to provide disc partition services. | |||
===Overlay allocation status=== | ===Overlay allocation status=== | ||
One critical limitation, mentioned above, is that the LiveOS persistent overlay is a allocate-once, fixed size, file space. This is related to its use of ''device mapper'' snapshots to combine a read-only file system image (copied from the compressed SquashFS.img on the read-only LiveCD or installation .iso file) with a [[wikipedia:Copy-on-write|Copy-on-write]] service that tracks only changed blocks of data in the snapshot (overlay) file and then re-referencing file pointers to the updated blocks.<ref>http://people.gnome.org/~markmc/code/merge-dm-snapshot.c</ref><ref>http://git.kernel.org/?p=linux/kernel/git/stable/linux-stable.git;a=blob;f=drivers/md/dm-snap-persistent.c;hb=HEAD</ref> | One critical limitation, mentioned above, is that the LiveOS persistent overlay is a allocate-once, fixed size, file space. This is related to its use of ''device mapper'' snapshots to combine a read-only file system image (copied from the compressed SquashFS.img on the read-only LiveCD or installation .iso file) with a [[wikipedia:Copy-on-write|Copy-on-write]] service that tracks only changed blocks of data in the snapshot (overlay) file and then re-referencing file pointers to the updated blocks.<ref>http://people.gnome.org/~markmc/code/merge-dm-snapshot.c</ref><ref>http://git.kernel.org/?p=linux/kernel/git/stable/linux-stable.git;a=blob;f=drivers/md/dm-snap-persistent.c;hb=HEAD</ref> Only changed sectors in files are stored in the overlay. "Deletions" of any original files in the base filesystem are recorded by changes in the index metadata so that the original file blocks are hidden. With this mechanism, no physical storage space of the read-only, base filesystem can be reused. The apparent free space in the virtual root filesystem as reported by the {{Code|df}} command will increase, but this additional space is not physically available; however, when a new or changed file is deleted, the new or changed sectors only (in the overlay) are available for reuse, but, unfortunately, the count of allocated sectors does not change, so one cannot be certain of the availability of free physical space after arbitrary changes to the root filesystem. | ||
With Fedora 24 (kernel 4.3+), if the overlay is filled, the overlay will enter a 'Overflow' state and the root file system will continue to operate in a read-only mode. See [[LiveOS image/overlay]] for instructions on how one may then either enlarge or merge the overlay. | |||
The status of the space allocated for persistent storage in the snapshot overlay file may be tracked with the ''device mapper'' {{Code|dmsetup status}} report. | The status of the space allocated for persistent storage in the snapshot overlay file may be tracked with the ''device mapper'' {{Code|dmsetup status}} report. | ||
Line 187: | Line 185: | ||
where the fraction after {{command|snapshot}} is the number of 512-byte sectors allocated in the overlay over the total number available in the overlay. (The final number is the metadata sectors allocated, and the number before {{command|snapshot}} is the apparent size of the virtual filesystem.) | where the fraction after {{command|snapshot}} is the number of 512-byte sectors allocated in the overlay over the total number available in the overlay. (The final number is the metadata sectors allocated, and the number before {{command|snapshot}} is the apparent size of the virtual filesystem.) | ||
Where long-term usage of a LiveOS image is anticipated, special attention to overlay consumption is advised. If memory or storage resources are available, one may take advantage of the {{Code|rd.writable.fsimg}} or {{Code|rd.live.overlay.size}} options in the [http://git.kernel.org/?p=boot/dracut/dracut.git;a=blob;f=modules.d/90dmsquash-live/dmsquash-live-root.sh;hb=HEAD /sbin/dmsquash-live-root] startup script to mitigate this risk of failure. | |||
: ( | : (For systems built before Fedora 24 that exhaust the overlay to an 'Invalid' state, last-ditch [[LiveOS image/overlay#Overlay recovery|recovery of a persistent overlay]] for the failed root filesystem may be attempted from a separate boot of a working system.) | ||
Several developments in the LiveOS design may be considered to maximize the endurance of the LiveOS image. | Several developments in the LiveOS design may be considered to maximize the endurance of the LiveOS image. | ||
==References== | ==References== | ||
<references /> | <references /> | ||
:: See this [http://thread.gmane.org/gmane.linux.kernel.device-mapper.devel/14644 dm-devel thread]. | :: See this [http://thread.gmane.org/gmane.linux.kernel.device-mapper.devel/14644 dm-devel thread]. | ||
Revision as of 17:53, 5 July 2016
Introduction
Fedora has developed Live CD USB DVD images for their GNU/Linux operating system. Since the image file systems are stored in the /LiveOS folder of the image, this is the name we'll use to reference the product.
This page shares some critical information about the LiveOS design that helps users take better advantage of their more-limited-than-usual disc resources.
References
- livecd-iso-to-disk Usage instructions are on the first pages (or on the manual page).
- FedoraLiveCD
- How to create and use a Live CD
- How to create and use Live USB
Storage
When a Live CD or Live DVD (a LiveOS image on read-only disc media) is booted, temporary storage is prepared for the system in RAM on each boot by /sbin/dmsquash-live-root in initrd.img, the initial ram disk filesystem. By default, a 0.5 GiB, in-memory, copy-on-write, system overlay in a sparse file is prepared (see File Systems below). The rd.live.overlay.size kernel command line option may be used to set a different, temporary, overlay size.
When the rd.live.overlay kernel command line option is provided on boot, such as with a Live USB device, the dmsquash-live-root.sh script will search for a persistent overlay file to use for storage of root filesystem changes. See Booting live images in the dracut package.
With Fedora 24 (kernel 4.3+), if the overlay is exhausted, the overlay will enter a 'Overflow' state and the root file system will continue to operate in a read-only mode. See LiveOS image/overlay for instructions on how one may then either enlarge or merge the overlay.
- Note: In systems built before Fedora 24, should the overlay storage space, whether temporary or persistent, be totally consumed, the filesystem will be flagged 'Invalid' and the system will crash with Input/output or Bus errors. If such a crash does occur while using temporary storage space for the overlay, a simple reboot will rectify the situation. With persistent storage the situation is more dire and will require appending rd.live.overlay.reset (formerly, reset_overlay) to the kernel command line on boot-up. This will vacate all changes to the root file system (though a persistent home filesystem, if used, will be unaffected). In either case, achieving a reboot will require a hard reset, since attempting a software initiated reboot on the Invalid filesystem will fail with more Input/output or Bus errors. See #Overlay allocation status for a way to monitor overlay consumption.
Operating system file systems
Live Operating System, LiveOS, file systems are found within disk image .img files.
If one mounts a Fedora-Workstation-Live.iso file or Live CD, the file system will list folders such as the following:
/EFI /images /isolinux /LiveOS |- squashfs.img (Systems before Fedora 24 also had these files |- livecd-iso-to-disk - a Bash script for installing the LiveOS image onto a USB device |- osmin.img - a minimized OS image formerly used to aid installation to a hard disk
The squashfs.img is a SquashFS compressed, read-only, file system holding the Fedora operating system root file system inside another LiveOS folder containing a rootfs.img file. Mounting the squashfs.img file and listing its file system will show this hierarchy:
/LiveOS |- rootfs.img (This contains a filesystem of type ext4. Before F-24 it was named ext3fs.img.)
Mounting the rootfs.img file will finally reveal the Fedora operating system root file system.
Here is a summary of the whole structure:
Fedora-Workstation-Live.iso !(mount) /EFI /image /isolinux /LiveOS |- squashfs.img !(mount) /LiveOS |- rootfs.img !(mount) /bin -> usr/bin /boot /dev /etc /home /lib -> usr/lib /lib64 -> usr/lib64 /lost+found /media /mnt /opt /proc /root /run /sbin -> usr/sbin /srv /sys /tmp /usr /var
When the LiveOS image is loaded onto a USB or SD disk, the isolinux folder is copied into a syslinux folder.
If persistence is requested with the --overlay-size-mb NNN option, a Device-mapper overlay file for the root file system is created in /LiveOS.
If a separate home file system is requested with the --home-size-mb NNN option, an ext4 formatted home.img file system is created.
The structure is then as follows:
Fedora-Workstation-Live USB/SD device !(mounted on /run/initramfs/live) (Before Fedora 17 the mount point is /mnt/live in the root file system.) /syslinux /LiveOS |- home.img !(mounted on /home) (This occurs during boot up by the /etc/rc.d/init.d/livesys script.) /liveuser /Desktop /Documents /Downloads ... /lost+found |- livecd-iso-to-disk |- overlay-NAME-XXXX-XXXX (Where NAME is the device partition name and XXXX are hex numerals.) |- squashfs.img !(mount) (At boot up by the /usr/sbin/dmsquash-live-root.sh script in the initramfs.) /LiveOS |- rootfs.img !(mounted on '/') (This occurs during boot up by the dmsquash-live-root.sh script.) /bin -> usr/bin /boot /dev /etc /home (If there is a home.img, then this is its mount point directory.)
If the --skipcompress option is used during loading with livecd-iso-to-disk, the squashfs.img compressed image will be expanded. The structure is then as follows:
Fedora-Workstation-Live USB/SD device !(mounted on /run/initramfs/live) /syslinux /LiveOS |- home.img !(mounted on /home) /liveuser /... |- livecd-iso-to-disk |- overlay-NAME-XXXX-XXXX |- rootfs.img !(mounted on '/') /bin -> usr/bin /boot /dev /etc /home ...
Persistent storage
The Fedora LiveOS system allows for persistent storage in 3 locations:
- An all-purpose, persistent overlay-based file space that saves all updates and changes to the root LiveOS filesystem. This storage space is limited by its allocate-once, fixed-sized design, and deserves some caution (see File Systems below).
- Persistent home filesystem - a re-writable, re-sizable (with difficulty), uncompressed, optionally-encryptable, file space for anything that goes in the user's /home/ folder. A persistent home filesystem is an option that may be selected at the time of installation of the LiveOS image (although with some effort, one could manually create a home.img filesystem in /LiveOS/ and move the /home/ folder to it). This installation option is only available through the script, 'livecd-iso-to-disk'. The Windows and Fedora 'Fedora Media Writer/Live USB Creator' installers do not provide this option at present.
- Host device file space - this is the underlying USB stick or SD card file system that is outside of the LiveOS file tree, but which is accessible through the /run/initramfs/live or /mnt/live (before Fedora 17) mount point of a booted LiveOS installation. There, one finds the boot configuration files and anything else one had on the device before loading the LiveOS image. One may save files here without consuming the other, limited file spaces. (This file space is limited only by the device capacity).
/run/initramfs/live /LiveOS |- home.img |- livecd-iso-to-disk |- overlay-NAME-XXXX-XXXX |- squashfs.img /syslinux
The all-purpose, persistent overlay is needed for operating system changes and updates.
The file systems are prepared on each boot by the /etc/rc.d/init.d/livesys script.
Home filesystem
One may find many advantages to installing the LiveOS, with a persistent, home folder (using the --home-size-mb NNN option), which will hold all the user files and documents one wishes and, perhaps later, throw away—all without consuming the overlay that can be consumed very quickly.
Device filesystem
Additionally, keeping some storage space on the device disc outside of the LiveOS system will let you copy, carry, and delete large resource files, such as image.iso files, or anything you might want to use or share.
Installation options
Fedora 24 Live Workstation may be installed on a 2 GB USB device using the following options with livecd-iso-to-disk (on a single, terminal or console command line, even though the wiki may wrap the following text to accommodate your browser window size):
- ./livecd-iso-to-disk --reset-mbr --overlay-size-mb 300 --home-size-mb 200 --unencrypted-home /path/to/source/iso/or/device /dev/sd?1
- where '?' in the final parameter represents the target bootable device node, such as sdb1 or sdc1, etc.
The above configuration would allow space for the home folder, the operating system, and a minimal amount on the device root.
But with a larger capacity device, one may allocate the resources to suit the anticipated use, as described above.
File Systems
Fedora LiveOS uses the Device-mapper service of the Linux kernel to manage the file stores on the device. This is the same service that is used by Logical Volume Manager to provide disc partition services.
Overlay allocation status
One critical limitation, mentioned above, is that the LiveOS persistent overlay is a allocate-once, fixed size, file space. This is related to its use of device mapper snapshots to combine a read-only file system image (copied from the compressed SquashFS.img on the read-only LiveCD or installation .iso file) with a Copy-on-write service that tracks only changed blocks of data in the snapshot (overlay) file and then re-referencing file pointers to the updated blocks.[1][2] Only changed sectors in files are stored in the overlay. "Deletions" of any original files in the base filesystem are recorded by changes in the index metadata so that the original file blocks are hidden. With this mechanism, no physical storage space of the read-only, base filesystem can be reused. The apparent free space in the virtual root filesystem as reported by the df command will increase, but this additional space is not physically available; however, when a new or changed file is deleted, the new or changed sectors only (in the overlay) are available for reuse, but, unfortunately, the count of allocated sectors does not change, so one cannot be certain of the availability of free physical space after arbitrary changes to the root filesystem.
With Fedora 24 (kernel 4.3+), if the overlay is filled, the overlay will enter a 'Overflow' state and the root file system will continue to operate in a read-only mode. See LiveOS image/overlay for instructions on how one may then either enlarge or merge the overlay.
The status of the space allocated for persistent storage in the snapshot overlay file may be tracked with the device mapper dmsetup status report.
For example, dmsetup status live-rw may return
live-rw: 0 8388608 snapshot 42296/1048576 176
where the fraction after snapshot
is the number of 512-byte sectors allocated in the overlay over the total number available in the overlay. (The final number is the metadata sectors allocated, and the number before snapshot
is the apparent size of the virtual filesystem.)
Where long-term usage of a LiveOS image is anticipated, special attention to overlay consumption is advised. If memory or storage resources are available, one may take advantage of the rd.writable.fsimg or rd.live.overlay.size options in the /sbin/dmsquash-live-root startup script to mitigate this risk of failure.
- (For systems built before Fedora 24 that exhaust the overlay to an 'Invalid' state, last-ditch recovery of a persistent overlay for the failed root filesystem may be attempted from a separate boot of a working system.)
Several developments in the LiveOS design may be considered to maximize the endurance of the LiveOS image.
References
- See this dm-devel thread.