From ArchWiki
Revision as of 13:22, 7 October 2010 by Zom (talk | contribs) (Trimming down boot-times: Since quick-init is now unsupported, we shouldn't mention it.)
Jump to: navigation, search

Readahead-fedora is originally developed by fedora, and contrary to ureadahead it doesn't require patching the kernel. It creates a list of files to put in the page cache before they're needed, thus reducing boot time.


  • It doesn't require patching the kernel.
  • It can take multiple lists of files to be preloaded, and sort them according to their position on the disk.
  • It preloads the inode tables on ext2-based file systems.
  • It opens the files without making the system update their access time, therefore avoiding extra disk writes. (Though, this shouldn't matter when using relatime or noatime I think)
  • It uses a lightweight monitoring daemon.

(List shamelessly stolen from the debian package description, original here)


Ying has created a PKGBUILD for this project, it can be found here.

Note: libprelude currently doesn't build with libtool-2.4. Either downgrade to 2.2.10-3 or wait for a workaround.


All configuration is done through /etc/readahead.conf. Some interesting variables might be:


A value in seconds that determine how long the collector should run.


A path to your init program. Change this if you use anything other than sysvinit.

RAC_EXECIGN="/sbin/readahead /usr/sbin/preload"

If you want the collector to ignore syscalls from certain programs, this is where you set their paths.

RAC_EXCLUDE="/proc /sys /dev /var/log /var/run /var/lock /home /tmp /var/tmp /media /selinux /mnt"

Directories to ignore while collecting. Anything that isn't needed during boot should probably be here to keep the list slimmed down.


The package installs the file /etc/rc.d/functions.d/readahead. This file will automatically start readahead at the appropriate times, control the collector and all that.

If you have dbus installed, readahead will automatically start it before X starts to avoid any issues.

The file /.readahead should automatically be created when installing the package. This is to let readahead-collector profile your system next boot.

Automated profiling

This is actually really easy, just add a cron job that creates the file /.readahead every month or so.

Manually reprofile the system

There are two ways to do this, either just run

$ touch /.readahead

as root, or you can temporarily add


to the kernel line in your bootloader. You should also disable auditd, because auditd deletes all audit rules during boot, which is contraproductive for the collector. Now, you just need to reboot and let the collector profile your system.

Trimming down boot-times

The package edits your inittab to take advantage of the early - later split in readahead-fedora. What it basically does is move these lines around:

#su:S:wait:/sbin/sulogin -p

# Example lines for starting a login manager
#x:5:respawn:/usr/bin/xdm -nodaemon
#x:5:respawn:/usr/sbin/gdm -nodaemon
#x:5:respawn:/usr/bin/kdm -nodaemon
#x:5:respawn:/usr/bin/slim >& /dev/null

rm:2345:wait:/etc/rc.multi > /dev/null
su:S:wait:/sbin/sulogin -p

# End of file
Note: The old inittab is backed up as /etc/inittab.backup

The idea of doing it this way is that readahead will put the needed X-stuff in the early cache. Thus, while X is starting it'll have time to read the later cache for starting the daemons.

Note: Since we can't have multi starting early, we can't use :once: instead of :wait: to make boot asynchronous


You might wonder what this file does while profiling:

readahead-later() {
  if [ -e /.readahead ]; then
      sleep 8
      touch /.switch-collector-to-later
      rm /.readahead

Readahead-fedora uses two steps to read and create the cache, called "early" and "later". Why it does it this way is to have a small, neat cache that it initially reads. This basically contains the basic files needed to boot together with X. After it's read those files and started X, it reads the "later" cache for starting the various daemons and services. This way, it tries to be a bit smarter and dynamic in hiding load times.