Template:Article summary start Template:Article summary text Template:Article summary heading Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary heading Template:Article summary link Template:Article summary link Template:Article summary end
e4rat（ext4 reduced access time'的简写）是一款将 Ext4 文件系统上文件块优化排序以加快系统和应用程序启动速度的程序。 项目主持人：Andreas Rid 和Gundolf Kiefer The the e4rat range of tools are comprised of e4rat-collect, e4rat-realloc and e4rat-preload.
- 1 步骤
- 2 安装
- 3 让其起作用
- 4 e4rat with different init system
- 5 启动监视图
- 6 常见问题
If you look at a classical bootchart you will notice that neither disk nor CPU are utilized fully during the boot process. e4rat changes this to make full use of both disk and CPU during boot process and thus reduce boot time drastically. It consists of three stages:
- e4rat-collect - collect files for a specified time (default 120 seconds but this can be adjusted)
- e4rat-realloc - reallocate files
- e4rat-preload - preload them
e4rat has proven to be extremely effective for typical single user set-ups which boot straight into X, perhaps even with a number of programs open. If you have a server set-up and boot only into the CLI your boot time decrease may not be as drastic. SSD drives do not benefit because there are no moving parts and thus (almost) no disk latency.
The following might have been valid for version 0.20. We are now at version 0.21 - please report findings for the latest version.
Caveat emptor: the current version of e4rat (0.20) will severely damage any partition that has been converted to ext4. This is likely because existing files are not converted to use extents, and e4rat has no built-in mechanism to detect this condition. Before using e4rat you should backup the affected partitions, reformat them as ext4 and then restore the backups. Given the current status and the nature of the program, it's a smart move to backup the system before attempting reallocation anyway.
Thepackage can be found in the [community] repository:
$ pacman -S e4rat
Now for the nitty-gritty:
To have e4rat collect a list of files you will need to append the following to your linux line in your /boot/grub/menu.lst (grub legacy) or /boot/grub/grub.cfg (grub2) file:
This will only have to be done once so you may prefer to append this command on the grub command line itself.
Upon booting e4rat-collect will watch your system for a default of 120 seconds. So if you boot, log into X, open your favourite browser and email client all within 2 minutes, every one of those activities is logged. To change the default of 120 seconds edit /etc/e4rat.conf. To manually stop e4rat-collect type:
Upon successful boot and after having waited the allotted time you should see the following file: /var/lib/e4rat/startup.log
Do not forget to remove the e4rat-collect command from your menu.lst or grub.cfg file (not necessary if you inserted it on the grub command line).
For the reallocation process change to init 1
sudo init 1
Log in as root and run:
This can take a while depending on how many files you have your startup.log file.
Append the following permanently to your kernel line in your /boot/grub/menu.lst (grub legacy) or /boot/grub/grub.cfg (grub2) file:
An alternative preload binairy has been developed by jlindgren, it shaves a few extra seconds from your boot time.
The savings come from
- using pure C with no external library dependencies, which drops the number of linked .so files from 22 to 3, and
- preloading only the first 100 files (both inodes and file contents) before starting /sbin/init, then continuing to load the remaining files in parallel with the normal boot sequence.
You can install AUR.AUR from the
Append (or replace) the following permanently to your kernel line in your /boot/grub/menu.lst (grub legacy) or /boot/grub/grub.cfg (grub2) file:
Reboot and enjoy.
e4rat with different init system
e4rat-collect defaults to replacing itself with /sbin/init upon completion. If you need to specify another PID 1, such as /bin/systemd, you can change this in /etc/e4rat.conf by setting the init parameter and uncommenting the line.
You will see a noticeable improvement but nothing can beat a nice Bootchart. Have it run before and after e4rat installation and gawk at the difference.
This version automatically stops logging as soon as ?dm comes up. Supposedly the following overrides that and continues logging but it doesn't work for me:
To continue logging adjust your /etc/bootchartd.conf as follows:
To stop it manually type:
~# bootchartd stop
To run both e4rat-preload and bootchart append the following to your grub kernel line:
To get bootchart2 working together with e4rat edit /sbin/bootchartd and replace the line init="/sbin/init" with "init="/sbin/e4rat-preload".
/etc/bootchartd.conf of bootchart2 is set up differently and the line
EXIT_PROC="kdm_greet xterm konsole gnome-terminal metacity mutter compiz ldm icewm-session enlightenment"
can be adjusted or left empty for logging to be stopped manually rather than at a predetermined programme start.
If things do not work you may want to try the following.
- comment out auditd from your rc.conf
- check the following for any hints
dmesg | grep e4rat
- try to increase verbosity and loglevel to 31 in your e4rat.conf
e4rat erroneously reports an ext2 files system
- add the following to the kernel line in your grub.cfg or menu.lst
- this suggests that you have /var on a separate partition which is not yet mounted during boot. You need move your startup.log to an accessible partition (/etc/e4rat/ is just fine) and adjust your /etc/e4rat.conf to reflect this change: