You are not logged in.

#1 2015-02-10 18:36:19

Bluerider
Member
Registered: 2012-07-22
Posts: 97

liveroot : Easy LiveBoot

Salutations,

I have written a some initcpio scripts to take advantage of the new Overlayfs feature in kernel 3.18. Adding the hooks to /etc/mkinitcpio.conf and the kernel cmdline will allow one to boot into a non persistent mode. It is similar to a liveboot, but simpler in my opinion. Croot uses a 1GB compressed ramdisk on top of root, oroot uses a tmpfs disk (half total amount of ram) on top of root. Any changes when running this mode will be lost on reboot.

https://aur.archlinux.org/packages/liveroot/

Offline

#2 2015-03-23 19:21:22

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

Well it's been a month since liveroot was first released. It now supports 3 forms of booting: live (run Arch Linux entirely on ram), compressed (run Arch Linux on a compressed ram block overlay), and raw (run Arch Linux on a tmpfs overlay). In addition, all these modes now generate a function called "overlay_flush". Overlay_flush lets one flush changes made on overlay (or on ram block device) to the backing disk. Why's this useful? Consider an OS that runs off of a USB. USB writes speeds are slow. One can run Arch Linux on one of these modes to avoid writing to the USB. When changes made are satisfactory, one can run overlay_flush to commit changes to the disk. One could easily turn this into a cronjob to do automatic syncing every hour or so.

Offline

#3 2015-04-01 03:53:27

justin-8
Member
From: Queensland, Australia
Registered: 2013-06-18
Posts: 53

Re: liveroot : Easy LiveBoot

Saw your post to aur-general the other day. Going to have to check this out sometime soon, it sounds really useful.

Offline

#4 2015-04-01 04:02:41

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

If we drop ISO support for the arch install img, we could just use liveroot + btrfs to generate a compressed installation img.
Easy to update, easy to modify.

Offline

#5 2015-04-03 09:38:00

Revelation60
Member
From: The Netherlands
Registered: 2009-03-19
Posts: 158
Website

Re: liveroot : Easy LiveBoot

Nice work, Bluerider!

Offline

#6 2015-04-13 00:03:31

Evex
Member
Registered: 2015-01-30
Posts: 7

Re: liveroot : Easy LiveBoot

Please pardon the lack of experience, but what is the difference between oroot=raw and oroot=live.

I'd like to make a Parted Magic-like USB that I can be removed once the OS has loaded and load on another machine.

I'd also like to have a separate entry in rEFInd that can used to update the OS. Would I have to make a separate initramfs-linux.img without the oroot hook or would I only need to have 2 entries (1 with and 1 without the kernel argument) and one initramfs-linux.img?

Offline

#7 2015-04-13 12:31:04

Head_on_a_Stick
Member
From: The Wirral
Registered: 2014-02-20
Posts: 8,480
Website

Re: liveroot : Easy LiveBoot

This is awesome!

Thank you Bluerider!
big_smile


Para todos todo, para nosotros nada

Offline

#8 2015-04-18 00:29:11

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

Evex wrote:

Please pardon the lack of experience, but what is the difference between oroot=raw and oroot=live.

I'd like to make a Parted Magic-like USB that I can be removed once the OS has loaded and load on another machine.

I'd also like to have a separate entry in rEFInd that can used to update the OS. Would I have to make a separate initramfs-linux.img without the oroot hook or would I only need to have 2 entries (1 with and 1 without the kernel argument) and one initramfs-linux.img?

This is entirely possible. Please see the examples in /usr/share/liveroot.
You compile oroot into the initramfs but it won't do anything if you don't call it in the kernel cmdline.

Offline

#9 2015-04-18 00:32:32

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

The AUR package now recognizes the static compiler. Oroot started getting kind of ugly (well I didn't like how it was becoming) so I wrote a bash -> bash compiler.
 
1)When you use the AUR package it'll ask if you want to use the compiler. If you say "y", the installed oroot will be highly specific to your system based on what it read off the current kernel cmdline.
2) Now some may wonder what that "btrfs" option is... In order for that mode to work, one needs to have a subvolume called /snapshots and an initial snapshot of the root file system. When using the btrfs version, a snapshot is made everytime overlay_flush is called. That's pretty neat in my opinion.

Offline

#10 2015-04-18 00:35:16

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

To all, if it works for you; consider voting for the package!
I think it's abilities are quite good...but no one seems to know about it.

Offline

#11 2015-04-18 00:37:28

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

Evex wrote:

Please pardon the lack of experience, but what is the difference between oroot=raw and oroot=live.

Oroot=raw means use a tmpfs (no compression) overlay. Oroot=live means load all of root into compressed ram block (requires lots of ram, roughly half of root's size).

Offline

#12 2015-04-18 16:40:43

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

I've received a request on advising boot times using liveroot.
This is a really difficult concept when it comes to liveroot since it is entirely dependent on the read speed of root. Liveroot speeds up boot and running programs by writing to a ram block device instead of to disk.  Otherwise it follows normal kernel cache policy meaning that it needs to read from stroage before caching the data. With that in mind, liveroot heavily benefits USB/SD based OS since they have low write speeds.

To get a rough measure of the speedup, divide the # of bytes needed to be loaded to reach userspace by the write speed of root. This should give you the # of seconds it takes to bootup.

In addition, liveroot doesn't only benefit bootup, since it writes to ram, it benefits all applications after they've been started up.

Since I run liveroot on a USB stick, I'd really rather not boot on disk (it will be excrutiating slow and waste my entire day).

Offline

#13 2015-04-18 17:08:25

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

Just to give an estimate :
Running on qemu with following parameters:

  • 2.5G partition

  • 1.8G allocated ram

  • USB : 32.3 MB/s read; 13.7 MB/s write; 1.56 msec access

  • zswap enabled

  • Gnome(X11) userspace

Note all times listed are in seconds

  1. oroot=compressed  : 12.657

  2. oroot=live                : 11.754

  3. disk                          :  52.459

I only ran a single test because using QEMU confounds things (Linux disk caching system; I'm using zswap)
In general:

  • oroot=raw has the fastest bootup

  • oroot=live has the slowest bootup but fastest I/O (magnitudes faster)

  • oroot=compressed is a good compromise between oroot=raw and ram usage

Last edited by Bluerider (2015-04-18 19:46:46)

Offline

#14 2015-04-18 19:45:47

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

Some more estimates on real hardware (sample size = 1).

  • 2.5G partition

  • 4G DDR3 ram

  • USB: 93.3 MB/s read; 21.3 MB/s write; 1.16 msec

  • zswap enabled

  • Gnome(X11) userspace

With a sample size of 1 (n=1) and time in seconds:

  1. oroot=compressed : 3.991

  2. oroot=raw               : 3.959

  3. oroot=live               : 2.699 (note, this doesn't include the 2:53.769 spent in kernel)

  4. disk                         : 23.832

Offline

#15 2015-04-19 01:11:44

teateawhy
Member
From: GER
Registered: 2012-03-05
Posts: 1,138
Website

Re: liveroot : Easy LiveBoot

If i'm reading this correctly, then archiso already has support for overlay filesystems. At line 40:

# args: source, newroot, mountpoint
_mnt_overlayfs() {
    local src="${1}"
    local newroot="${2}"
    local mnt="${3}"
    mkdir -p /run/archiso/cowspace/${cow_directory}/upperdir /run/archiso/cowspace/${cow_directory}/workdir
    mount -t overlay -o lowerdir=${src},upperdir=/run/archiso/cowspace/${cow_directory}/upperdir,workdir=/run/archiso/cowspace/${cow_directory}/workdir airootfs "${newroot}${mnt}"
}

Offline

#16 2015-04-19 03:01:42

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

Oh wow, that's interesting. Why does the arch iso use squashed FS then?

In addition, the kind of Arch ISO upgrade I'm talking about can be found in the btrfs version of liveroot. You can access it via the compiler. If you create a subvolume named /snapshots, you can use liveroot's overlay_flush generates snapshots. When you run in oroot=live mode, you will load the last snapshot which means you can now have multiple Arch ISO versions on the same ISO.
Updating the ISO would be a matter of updating and creating snapshots.

Offline

#17 2015-04-19 15:54:23

teateawhy
Member
From: GER
Registered: 2012-03-05
Posts: 1,138
Website

Re: liveroot : Easy LiveBoot

Bluerider wrote:

Oh wow, that's interesting. Why does the arch iso use squashed FS then?

Squahsfs is needed to compress the ext4 filesystem. Without squashfs the filesytem would be too big to fit on a CD.

In addition, the kind of Arch ISO upgrade I'm talking about can be found in the btrfs version of liveroot. You can access it via the compiler. If you create a subvolume named /snapshots, you can use liveroot's overlay_flush generates snapshots. When you run in oroot=live mode, you will load the last snapshot which means you can now have multiple Arch ISO versions on the same ISO.
Updating the ISO would be a matter of updating and creating snapshots.

I forgot to say that your contribution is very interesting. What you have explained here is not possible with the current archiso scripts. A problem is see is that ISO files are READ ONLY by definition, which means you can't update the ISO without generating a new one. What does work is copying the filesystem directly to a USB stick without using an ISO file though.

You have to consider that compressed btrfs filesytems compress each file individually, whereas squashfs compresses all the files in a filesystem at once into a single file. Thus squashfs has most likely a better compression ratio than btrfs compression. Would be interesting too see the size difference between both.

Offline

#18 2015-04-19 17:20:52

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

Why yes. I mention that using it for an Arch ISO would require dropping the ISO requirement and using a simple raw image.

Offline

#19 2015-04-23 19:43:43

teateawhy
Member
From: GER
Registered: 2012-03-05
Posts: 1,138
Website

Re: liveroot : Easy LiveBoot

I've got an idea for the arch iso topic. There are a lot of duplicated files in the x86 and i686 images of archiso, especially in the /usr directory. It could help to run the btrfs deduplication tool duperemove for space savings.
https://aur.archlinux.org/packages/duperemove

Offline

#20 2015-04-23 20:05:57

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

Interesting. We could also just package the duplicate files as a separate overlay layer and mount it during liveroot's mount.

Offline

#21 2015-04-23 20:08:17

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

You have to consider that compressed btrfs filesytems compress each file individually, whereas squashfs compresses all the files in a filesystem at once into a single file. Thus squashfs has most likely a better compression ratio than btrfs compression. Would be interesting too see the size difference between both.

Generally btrfs compression will be worse than squashfs since squashfs uses gzip and btrfs uses lzo/lz4. However, the flexibility one gains when using btrfs (as are most flexibilities with read/write systems) are more useful to me.

Offline

#22 2015-04-23 20:33:16

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

An interesting idea I had while running liveroot was the realization that pacman pkgs are compressed well with xz. One way to save space on a live usb would be to only sync the home folder with overlay_flush and then have a list of packages to install before starting up the system. I may offer that as a function of liveroot. It'll require the pacman cache.

Offline

#23 2015-04-23 22:13:04

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

The new option : oroot=package can be found in the packages branch of liveroot. It is only available by activating the compiler (bash compiler). Note, it is extremely experimental and not tested.

Last edited by Bluerider (2015-04-23 22:41:46)

Offline

#24 2015-04-24 03:15:20

Bluerider
Member
Registered: 2012-07-22
Posts: 97

Re: liveroot : Easy LiveBoot

The new option is basically done. There are some caveats.

  • Requires /var/cache/pacman/pkg to contain packages

  • Requires only one copy of each package (no old versions) in the cache

  • overlay_flush only syncs the home folder with oroot=packages

Here's some benchmarks on qemu with 1.8G ram, 2 cpu cores. All units are in (minutes:seconds)

  1. oroot=live            :3:07.21(kernel)     1.108(live)

  2. oroot=packages  :1:53.044 (kernel)  2.770 (packages)

Offline

#25 2015-07-03 11:26:25

darthearon
Member
Registered: 2014-04-01
Posts: 24

Re: liveroot : Easy LiveBoot

Is their no documentation on how to actually use liveroot? Im kind of stranded on thread when looking throught the formums and google.

maybe a short tutoriaol or something?

here is what i have done so far.

1. Install liveroot from the aur.

2. cp /use/share/mkinitthingy.conf to /etc/mkThingyMaBob.conf (after backing up)

3. added oroot=live to the kernel cmd line (well I think i did anyway, i hit "e" at the grub prompt and added that to the linux line)

Last edited by darthearon (2015-07-03 11:29:15)


Cya At The Table

Offline

Board footer

Powered by FluxBB