E4rat: Unterschied zwischen den Versionen
Keine Bearbeitungszusammenfassung |
Keine Bearbeitungszusammenfassung |
||
Zeile 54: | Zeile 54: | ||
Beim nächsten Start sollten sich die Geschwindigkeitsvorteile deutlich bemerkbar machen. | Beim nächsten Start sollten sich die Geschwindigkeitsvorteile deutlich bemerkbar machen. | ||
==e4rat | ==e4rat mit anderem init-System== | ||
e4rat-collect | Standartmäßig ist e4rat-collect so eingestellt, dass es sich selbst mit /sbin/init nach erfolgreichem Ausführen ersetzt. Falls man jedoch einen anderen PID 1 benötigt, kann man den '''init'''-Parameter in /etc/e4rat.conf verändern, indem man die zugehörige Zeile auskommentiert. | ||
==Tips und Tricks== | ==Tips und Tricks== | ||
Zeile 68: | Zeile 68: | ||
*man versuche auf mehr Fehlermeldungen zu stoßen, indem man die Priorität der Lognachrichten und der Ausgabe auf 31 in '''e4rat.conf''' stellt | *man versuche auf mehr Fehlermeldungen zu stoßen, indem man die Priorität der Lognachrichten und der Ausgabe auf 31 in '''e4rat.conf''' stellt | ||
===e4rat beschwert sich fälschlicherweise über ein ext2-Dateisystem=== | ===e4rat beschwert sich fälschlicherweise über ein ext2-Dateisystem=== | ||
*man füge folgenden Eintrag zur 'kernel'-Zeile des Bootloaders hinzu: | *man füge folgenden Eintrag zur 'kernel'-Zeile des Bootloaders hinzu: | ||
rootfstype=ext4 | rootfstype=ext4 |
Version vom 29. August 2011, 11:12 Uhr
e4rat steht für e4 "reduced access time" und ist ein Projekt von Andreas Rid und Gundolf Kiefer. Die Software setzt sich aus drei Teilen zusammen: e4rat-collect, e4rat-realloc und e4rat-preload.
Derzeit ist die Version 0.2.1 aktuell. Wie aus dem Namen schon hervorgeht, funktioniert diese Software nur mit dem ext4-Dateisystem!
Arbeitsweise
Betrachtet man einen gewöhnlichen Bootvorgang, dann stellt man fest, dass weder der Prozessor noch die Festplatte währendessen vollkommen ausgelastet sind. e4rat sorgt für eine hohe Auslastung der Festplatte und der CPU während des Systemstarts und reduziert somit die Startzeit immens. Dabei müssen drei Schritte durchlaufen werden:
- e4rat-collect - Erstellt eine Liste der beim Start benötigten Dateien in einem festgelegtem Zeitraum (Standartwert sind 120 Sekunden. Dieser kann aber angepasst werden)
- e4rat-realloc - Umsortieren der gelisteten Daten direkt auf dem Datenträger
- e4rat-preload - Vorheriges Laden der Dateien
Wem es etwas nützt, und wem nicht
Beim booten in den X-Server auf typischen Einzeluser-Systemen hat sich e4rat schon oft als sehr effizient erwiesen. Handelt es sich jedoch beim Rechner um einen Server, welcher nur in die Kommandozeile bootet, wird sich der Speedgewinn sehr in Grenzen halten. Weiterhin profitieren auch SSDs nicht sehr stark vom Umsortieren der Daten, da die Latenzen bei SSDs in der Regel unabhängig von der Position der Dateien auf dem Datenträger sind.
Achtung: Die Version 0.20 zerstörte noch komplette Dateisysteme, welche zu ext4-Systemen umgewandelt worden waren. Es wird generell geraten vor Installation und Verwendung der Tools ein Backup der auf der Partition befindlichen Dateien zu erstellen!
Installation
e4rat ist im AUR zu finden: Vorlage:Package AUR
Verwendung
e4rat-collect
Um e4rat-collect dazu zu bewegen, die Liste der beim Boot benötigten Dateien zu erstellen, ist es notwendig in der 'Kernel'-Zeile der Bootloader-Konfiguration (/boot/grub/menu.lst (grub legacy) oder /boot/grub/grub.cfg (grub2)) folgendes hinzuzufügen:
init=/sbin/e4rat-collect
Dies muss nur ein einziges Mal getan werden, weshalb die Zeile nach dem ersten Boot wieder von der Eingabe bereinigt werden sollte.
Da e4rat-collect die ersten 120 Sekunden des Bootvorgangs überwacht (dies kann in /etc/e4rat.conf geändert werden), ist es weiterhin ratsam, sich einzuloggen und danach alle oft verwendeten Programm zu starten. Denn deren benötigten Dateien werden auch gecached werden. Dies führt dazu, dass der Systemstart nicht nur schneller von statten geht, sondern auch dass oft verwendete Programme so gut wie augenblicklich gestartet werden können.
Um e4rat-collect manuell zu deaktivieren benutzt man entweder:
e4rat-collect -k
oder:
pkill e4rat-collect
Nach einem erfolgreichen Start und nachdem die eingestelle Wartezeit verstrichen ist, sollte folgende Datei existieren: /var/lib/e4rat/startup.log
Man sollte daran denken den Eintrag in die Konfigurationsdatei des Bootloaders wieder zu entfernen, sofern man den Befehl für die Analyse der beim Start benötigten Dateien nicht während des Bootvorgangs im Bootloader lediglich temporär hinzugefügt hat.
e4rat-realloc
Für die Umsortierung der Dateien, sollte man in Runlevel 1 wechseln:
sudo init 1
Als root eingeloggt:
e4rat-realloc /var/lib/e4rat/startup.log
Je nachdem wie viele Dateien in startup.log aufgelistet sind, kann dieser Prozess einige Zeit in Anspruch nehmen.
e4rat-preload
Um sich die vorgenommenen Anpassungen zunutze machen zu können, ist folgender Eintrag in die 'kernel'-Zeile der Konfigurationsdatei des Bootloaders (/boot/grub/menu.lst (grub legacy) oder /boot/grub/grub.cfg (grub2)) notwendig:
init=/sbin/e4rat-preload
Beim nächsten Start sollten sich die Geschwindigkeitsvorteile deutlich bemerkbar machen.
e4rat mit anderem init-System
Standartmäßig ist e4rat-collect so eingestellt, dass es sich selbst mit /sbin/init nach erfolgreichem Ausführen ersetzt. Falls man jedoch einen anderen PID 1 benötigt, kann man den init-Parameter in /etc/e4rat.conf verändern, indem man die zugehörige Zeile auskommentiert.
Tips und Tricks
Falls etwas nicht wie beschrieben funktionieren sollte, gibt es einige Möglichkeiten dies zu beheben:
startup.log wird nicht erstellt
- man kommentiere auditd aus rc.conf aus.
- man überprüfe die Ausgabe von folgendem Befehl auf etwaige Fehlermeldungen:
dmesg | grep e4rat
- man versuche auf mehr Fehlermeldungen zu stoßen, indem man die Priorität der Lognachrichten und der Ausgabe auf 31 in e4rat.conf stellt
e4rat beschwert sich fälschlicherweise über ein ext2-Dateisystem
- man füge folgenden Eintrag zur 'kernel'-Zeile des Bootloaders hinzu:
rootfstype=ext4