Apt-Pinning. Ein oft genanntes Stichwort bei Debian und Co. Manchmal möchte man eine neuere Softwareversion installieren als diejenige, die in einer bestimmten Veröffentlichung von Debian- oder Ubuntu vorhanden ist. Die Gründe sind vielfältig. Vielleicht ist man lediglich an einem neuen Feature interessiert, andererseits kann man aber genauso gut auch auf ein neues Paket angewiesen sein oder es ausschließlich aus Neugier installieren. Für Debian Stable gibt es genau aus diesem Grund das offizielle Backport-Projekt, mit dem sichergestellt ist, dass ausgewählte Pakete zwar aktueller sind als die bestehenden, aber immer noch stabil mit dem Gesamtsystem harmonieren. Mit Apt-Pinning gibt es eine weitere Möglichkeit für erfahrene und fortgeschrittene Anwender aktuellere Software zu installieren. Insbesondere ist diese Methode für Debian Testing und Unstable interessant, wenn man z.B. Pakete aus dem Experimental Zweig zusätzlich installieren möchte und es kann unter Umständen auch für Debian Stable eine Option sein, wenn keine Backports vorhanden sind. Meine Motivation für diesen Beitrag waren zwei Pakete in Debian Testing, die nicht aktualisiert wurden, obwohl in Unstable eine Version vorhanden war, die Bugs beseitigte. Im Regelfall bin ich der typische, langweilige Debianbenutzer. Bei meinen Stable-Installationen läuft nur Stable, bei Testing nur Testing und bei Unstable...nur Unstable. Das ist zwar wenig aufregend, hat mich bisher aber immer vor instabilem Paket-Mischmasch bewahrt. Manche ätzen, dass das Mischen von Paketen später nur mit der Suche nach Hilfe in irgendwelchen Foren oder IRC-Channels enden kann, wo die Methusalems dich erst einmal zu Abbitte und Buße auffordern. Du möchtest nicht wissen, was mit Leuten passiert, die eingestehen Ubuntu-PPAs mit Debianpaketen gemischt zu haben. Ihr seid also gewarnt! 😈 Apt-Pinning wird ausführlich und gut mit man apt_preferences erklärt. Hilfreich finde ich außerdem
Bei meinem konkreten Problem ging es um Vim und Iceweasel. Vor einem Monat wurde ich durch Zufall auf #debian im IRC auf einen Bug in Vim aufmerksam gemacht, den ich zwei Stunden später dann per Reportbug gemeldet habe. Die Bearbeitung und Lösung des Problems war mustergültig. Der Paketverwalter bestätigte den Fehler und knapp zwei Wochen später war der Bug durch Upstream gefixt worden und das neue Paket in Debian Unstable. Doch auch Wochen danach kam davon nichts in Testing an. Mittlerweile hat es das Paket zwar nach Testing geschafft, doch gerade in so einem Fall kann Apt-Pinning weiterhelfen. Mein anderer Favorit ist Iceweasel. In der Regel folge ich den Anweisungen auf mozilla.debian.net und habe zum gleichen Thema auch schon einen Beitrag geschrieben. Im Moment dauert es aber mal wieder mit dem Versionswechsel von 7 auf 8 und 9 ist nicht mehr weit entfernt.
Apt-Pinning Pin-Priorität
In einem solchen Fall ist Apt-Pinning sehr einfach global einzurichten. Standardmäßig wird jedem Paket, jeder Installation und Aktualisierung eine Priorität zugewiesen, von der man in der Regel gar nichts mitbekommt. Alle installierten Pakete haben Prioriät 100, alle anderen Pakete innerhalb einer Version wie z.B. Squeeze 500. Überprüfen lässt sich das mit
apt-cache policy
Die Zahlenwerte haben laut man apt_preferences eine unterschiedliche Gewichtung. Im Allgemeinen gilt umso höher der Zahlenwert, desto höher die Priorität ein Paket aus einer anderen Version zu installieren. Für mich funktioniert das Folgende ziemlich gut: Erstellt euch in /etc/apt/apt.conf.d/ eine Datei mit beliebigem Namen. Ich habe hier 10default-release gewählt und editiert sie mit folgendem Inhalt. Z.B.:
APT::Default-Release "testing";
Das gilt natürlich nur für Debian Testing und sollte auf die entsprechende Debian Version geändert werden, die man gerade benutzt. Führt man danach ein aptitude update aus und anschließend apt-cache policy stellt man fest, dass sich die Priorität für die Pakete in Debian Testing auf 990 erhöht hat. Zwar wäre das Folgende auch ohne diese Festlegung machbar gewesen, mir hilft es aber sicherzustellen, dass bei zukünftigen Updates immer Testing Pakete vor allen anderen bevorzugt werden. Um nun Vim oder Iceweasel aus Debian Unstable zu installieren, muss man zuerst die Paketquellen in /etc/apt/sources.list aktualisieren und z.B. folgenden Eintrag für Unstable hinzufügen.
deb http://ftp.de.debian.org/debian unstable main
Danach lässt sich Iceweasel oder Vim aus Unstable mit
aptitude -t unstable install iceweasel vim
installieren. Bei zukünftigen Updates prüft Apt, ob die Version aus Unstable oder Testing neuer sein sollte. Da Testing bei mir eine höhere Priorität bekommen hat, wird im Zweifelsfall immer aus Testing installiert. Das ist natürlich noch nicht alles. Apt kann mehr, viel mehr. Wenn ihr Ubuntu benutzt lässt sich z.B. explizit festlegen, ob ihr nur Pakete aus 10.04 bevorzugt oder doch besser 11.04. Wie wäre es, wenn man festlegen könnte, ob man nur bis Version X aus Debian Testing installiert und danach nur noch Pakete aus Experimental installiert? Wie schränke ich meine Prioritäten nur auf KDE-Pakete ein? Apt ist ein wirklich sehr mächtiges und smartes Programm. Doch in der Regel kommt man wie oben beschrieben schon mit sehr wenig Aufwand aus und sollte beim Mischen von Paketen verschiedener Versionen immer skeptisch bleiben. Für alle, die sich eine maßgeschneiderte Preferences-Datei anlegen möchten, empfehle ich wie schon gesagt einen Blick in man apt_preferences zu werfen oder sich das folgende fortgeschrittene Beispiel anzuschauen. Raphael Hertzog bezeichnete vor sieben Monaten die Installation von Gnome 3 aus Debian Experimental in Testing als "apt-pinning for the brave". Das zu bewerten, liegt wie immer bei euch. 😉
Vergangene Woche habe ich begonnen TinyCore etwas genauer unter die Lupe zu nehmen und die kleine Linuxdistribution auf einen USB-Stick installiert, von dem aus schließlich alles in den RAM meines Thinkpad 600 kopiert werden konnte. Noch nicht alles war perfekt. Der voreingestellte XVesa-Treiber versperrte mir den Blick auf den Desktop mit einem grünlich-blauen Schleier. Ich habe zwar noch eine Weile im Internet recherchiert, konnte aber keine Lösung zu dem XVesa-Problem finden. Es wurde also Zeit TinyCore zu remastern, was in der Fachsprache dieser Linuxdistribution nichts anderes bedeutet als zusätzliche Softwarepakete zu installieren, überflüssige zu deinstallieren und die Stellschraube an der oder anderen Config-Datei zu drehen. TC bietet hier verschiedene Lösungsmöglichkeiten an:
Alle drei Methoden haben Vor-und Nachteile. Die Zu-Fuß-Methode setzt voraus, dass man sich wohl auf der Konsole fühlt, qremaster ist ein Shellskript, welches den Vorgang stark vereinfacht und Ezremaster ist ein grafisches Frontend, welches den gesamten Vorgang noch besser visualisiert und möglicherweise am intuitivsten ist.
TinyCore mit Hilfe von Ezremaster erweitern
Pfad zum TinyCore-Abbild und zum temporären Verzeichnis
Im ersten Schritt wählt man das Verzeichnis, indem sich entweder das multicore.iso, tinycore.iso, microcore.iso oder eine gemountete CD befindet. Die ISO-Dateien als Loop Device zu mounten funktioniert auch. Für mich war das /mnt/sr0 in Virtualbox. Für den Vorgang des Remasterns ist ein temporäres Verzeichnis notwendig, welches standardmäßig /tmp/ezremaster ist. Wer sehr viele Extensions, also neue Pakete, installieren möchte, sollte darüber nachdenken das Verzeichnis ggf. außerhalb von /tmp anzulegen, vor allem wenn RAM knapp ist.
Boot-Codes und Backup
Als nächstes lässt sich festlegen, mit welchen Boot Codes TinyCore gestartet werden soll. Für mich musste ich hier keine Einstellungen vornehmen. Wer aber z.B. Probleme mit der Auflösung hat, kann hier einen entsprechenden Parameter wie vga=791 für 1024x768 übergeben. Die sogenannte Backupdatei bietet die Möglichkeit gesicherte Einstellungen aus einer anderen TC-Installation in das neue Abbild zu übernehmen.
Extensions installieren
Der dritte Schritt ist das Installieren der zusätzlichen Software. Damit mein Thinkpad 600 wieder ein klares Bild liefert, habe ich mich für Xorg-7.6 entschieden, wozu ich mich zuerst mit dem Repositorium von TinyCore verbinden musste. Mit einem Klick auf "Connect to App Repo" ist dieses Thema abgehakt. Danach hat man folgende Möglichkeiten laut TinyCore Wiki.
Add App Outside initrd on boot / Add App Outside initrd. Diese Optionen werden die Erweiterungen im ISO-Image unter /tce/optional installieren. Wählt man Outside initrd apps on boot werden die Extensions zusätzlich in der Datei /tce/optional/onboot.lst aufgeführt, so dass sie automatisch beim Booten in den Arbeitsspeicher geladen werden. Die Methode Erweiterungen außerhalb der initial ramdisk zu installieren hat den Vorteil, dass weniger RAM notwendig ist um die Programme auszuführen. Die CD oder der USB-Stick darf dann aber nicht entfernt werden. Des Weiteren gibt es noch die Möglichkeit "copy2fs.flg" zu setzen, was dazu führt, dass die Erweiterung beim Booten schon in den RAM kopiert werden und das Installationsmedium danach entfernt werden kann. Das führt aber wieder zu mehr Speicherverbrauch.
Add App inside initrd on boot / Add App inside initrd. Diese Option installiert die Erweiterungen in die Initial-RAM-Disk (tinycore.gz) unter /opt/tce/optional. Wenn man "Inside initrd on boot" ausgewählt hat, werden die Namen der Extensions in die Datei /opt/tce/optional/onboot.lst geschrieben, so dass sie direkt beim Booten in den RAM kopiert werden und die CD/USB-Stick danach entfernt werden kann. Eine gute Methode, wenn man genügend Arbeitsspeicher zur Verfügung hat.
Add App Extract TCZ to initrd. Bei dieser Methode wird jede Extension beim Remasterprozess gemountet und in die extrahierte initrd installiert. Das soll eine bessere Performance als die "inside initrd" Option liefern bei gleichzeitig aber etwas größerem Speicherverbrauch, da nun die Extensions nicht mehr als komprimierte TCZ-Dateien vorliegen.
Ich habe mich für "Add App inside initrd on boot" entschieden, da ich später alle Anwendungen im RAM laufen lassen und den USB-Stick entfernen möchte.
Remaster-Prozess: Anfang
Ab hier beginnt das eigentliche Remastern. Wer den Vorgang im Terminal beobachten möchte, wählt einfach die Checkbox aus. Der Vorgang kann, je nach dem wie viele Erweiterungen installiert werden sollen, eine Weile dauern.
Remaster-Prozess: Finale
Im letzten Schritt wird schließlich eine neue ISO-Datei erstellt, die sich danach erneut auf eine CD schreiben oder in Virtualbox mounten lässt. Bevor das aber geschieht, kann man ab jetzt noch verschiedene Konfigurationsdateien ändern und Veränderungen am Dateisystem selbst vornehmen. Wie in Schritt 3. schon erklärt, befinden sich die Extensions später in /opt/tce/optional. Hat man den Standardpfad für die temporären Dateien beibehalten, findet man die Erweiterungen vor dem Erstellen der ISO-Datei unter /tmp/ezremaster/extract/opt/tce/optional und kann überprüfen, ob zuvor alles glatt gelaufen ist. Im Verzeichnis /tmp/ezremaster/image/cde/optional befinden sich die Erweiterungen für die MultiCore-Version. Falls man in der neu erstellten ISO-Version auf die Tools zum Remastern verzichten kann, ist hier der richtige Ort um sie zu entfernen. Wenn man wieder alles auf einen USB-Stick schreiben möchte, muss man nur die neue Datei tinycore.gz in /tmp/ezremaster/image/boot/ auswählen und wie im alten Beitrag geschrieben weiter verfahren.
Das Ergebnis
Der X-Server wird automatisch mit Xorg eingerichtet. Insgesamt belegt das System ca. 100 MB im RAM und ist naturgemäß äußerst schnell. Der Speicherverbrauch ist aber noch zu hoch, da ich die zusätzlichen Extensions der MultiCore-Version noch nicht entfernt habe. Hier muss ich also in Zukunft noch ein wenig Hand anlegen. Positiv ist auch, dass meine ASUS WL-107G WLAN Karte automatisch erkannt wurde und mir TinyCores Wifi-Programm nun schon den Access Point anzeigt. Als nächstes werde ich noch Dropbear als SSH-Server und einen Browser installieren und dann....mal schaun. 😉
Was machst du von heute an in zehn Jahren? Wie wird dein Leben aussehen? Wo wirst du wohnen, arbeiten, deine Zeit verbringen? Wenn du ein Medium mit Interessen für ältere Computer und Linux bist und durch einen aberwitzigen Zufall auf diese Seite geraten sein solltest, kennst du die Antwort vielleicht schon. Für Normalsterbliche ist ein Blick in die Glaskugel mitunter jedoch ziemlich trübe. Auch ich weiß nicht, was in der Zukunft passieren wird, weshalb ich mich in diesem Post einer verlässlicheren Größe zuwende - der Vergangenheit. Ich hatte Lust mir alte Rezensionen zu meiner Hardware anzuschauen und herauszufinden wie hoch die Verkaufspreise damals ausfielen. Hier also ohne Wertung ein paar Informationen dazu.
Dell Inspiron 4000
Der Inspiron kam Ende 2000 zum ersten Mal in den Handel. Auf pcpro.co.uk kostete er damals 1.996 Englische Pfund (1999: 1 Pfund = ca. 3DM) . Bei Testberichten auf dooyoo.de variierte der Preis im Jahr 2001 zwischen 5500DM (2.812€) bis ca. 1.700€ im gleichen Jahr. Ich kaufte ihn im Jahr 2008 gebraucht für 100€ inklusive Zubehör. Die meisten Kommentatoren hoben das helle und gute Display hervor und störten sich manchmal am Gehäuse oder den Lautsprecherboxen. Insgesamt sei er ein solider Laptop und diesen Eindruck kann ich auch heute noch bestätigen.
Toshiba Portégé 3110CT
Das Toshiba Subnotebook erschien im Jahr 1999 und wurde am 1.10.1999 auf pcpro.co.uk vorgestellt. Es kostete damals ca. 1.992 Englische Pfund. Auf dooyoo.de wurde er als ideal für Präsentationen oder als "mobile office" angepriesen. Auch im Jahr 2001 scheint er noch stolze 5000DM gekostet zu haben. Wer aber den 3110CT mal in Echt gesehen hat, wundert sich bei der kompakten Bauweise aus dem Jahr 1999 auch nicht mehr über den damaligen Preis. 2008 habe ich ihn netterweise für lau als Geschenk erhalten.
Toshiba Satellite 220cs
Cnet.com preist das "multimedia excitement and versatility" an. Auf expertreviews.co.uk wird das verbesserte 800x600 Pixel Display gegenüber den älteren 640x480 Pixeln hervorgehoben. Preislich musste man dafür am 01.09.1997 1.757 Englische Pfund hinlegen, was ca. 2500€ damals entsprochen hätte. Den 220cs habe ich letztes Jahr für 18 € bei ebay ersteigert.
IBM Thinkpad 600
Den Cnet.com Artikel zum Thinkpad 600 hatte ich schon vorgestellt. Der Artikel ist voll des Lobes über den nur 5 Pfund schweren Laptop mit einem "schreiend schnellen Pentium II Prozessor". Ersteigert habe ich ihn vor wenigen Monaten für 27,50 € bei ebay. In der offiziellen Pressemitteilung von IBM aus dem Jahr 1998 wird ein Verkaufspreis von 3199$ offeriert. Das war noch zu einer Zeit als der Dollar etwas mehr wert war als heute. 😉
Ein aktueller Trend ist der Austausch der althergebrachten elektromechanischen Festplatte gegen ein Solid State Drive und über kurz oder lang wird SSD die hergebrachte Magnetfestplatte vollständig ersetzen. Einziger Nachteil momentan ist der relativ hohe Preis pro GB für die neue Technologie. Für einen älteren Laptop mit einer zehnjährigen Vergangenheit lohnt ein solcher Umbau schon nicht mehr. Wer aber dennoch mit SD-Technik liebäugelt, aber nicht gerne Geld zum Fenster herauswirft, sollte sich auch einmal K.Mandlas SSD-Lösung näher anschauen. 😉 Für meinen Teil sehe ich sowohl für ältere als auch für brandneue Rechner eine noch preisgünstigere und noch schnellere Alternative.
RAM Installation
Machen wir uns nichts vor, heutzutage sind ja nun mehr 8 GB RAM Standard. Tendenz weiter steigend. Man muss schon ein außergewöhnliches Kunststück vollbringen, um mit einem Desktop-PC hier an die Grenzen zu stoßen. Hält man das System hingegen sogar schlank und minimal, lässt sich auch mit weit weniger RAM eine Linuxdistribution komplett in den RAM kopieren und darin dann ausführen. Und mal ehrlich, welchen Grund außer Nostalgie könnte es geben, dass Anwendungen nicht mit Lichtgeschwindigkeit starten sollten? In der Vergangenheit habe ich mir einige Linuxe angeschaut, die sich zur Hauptaufgabe gemacht haben, ein Betriebssystem für den RAM zu entwickeln. Darunter waren Slitaz, Puppy Linux, auch ArchBang bietet einen RAM-Modus an und nicht zu vergessen das winzige TinyCore. Im Grunde genommen lässt sich jede Linuxdistribution zum RAM-Linux umrüsten. Der Unterschied besteht hauptsächlich darin, wie viel Arbeitsspeicher vorausgesetzt wird und wie einfach oder schwer es gemacht wird das System an die eigenen Vorstellungen anzupassen. Gut gefallen hat mir das einfache Konzept von Slitaz, wo man dem im RAM laufenden Linux Anwendungen hinzufügen oder entfernen kann und mit dem sich das fertige Ergebnis sofort wieder zu einer neuen ISO-Datei zusammenstellen lässt.
TinyCore auf einem USB-Stick
Um den Horizont zu erweitern versuche ich mich derzeit an TinyCore Linux, welches den Thinkpad 600 und vielleicht später sogar den Toshiba Portégé 3110CT komplett als RAM-Distribution antreiben soll. Ähnlich wie bei Slitaz bietet TinyCore einen eigenen Installer, der das Image auf den USB-Stick schreibt und diesen zugleich bootfähig macht. Die Dokumentation dazu ist meiner Meinung nach etwas inkonsistent. Gleichzeitig ist die Installation auf den USB-Stick aber ziemlich einfach. Ansehen sollte man sich die Installationsanleitung, das Quick&Easy Overview und auch das TinyCore-Wiki.
Zuerst habe ich mir das MultiCore Image heruntergeladen, auf dem sich die zusätzlichen Programme zum Installieren befinden.
Anschließend wurde die ISO-Datei in Virtualbox als CD-Laufwerk in einer virtuellen Maschine gemountet und von dort die MultiCore-Version gestartet. Natürlich habt ihr auch die Möglichkeit das Abbild auf CD zu brennen.
Auf dem Desktop angekommen, startet ihr den TC-Installer (zweites Icon von rechts auf dem Screenshot).
Wählt die Datei tinycore.gz aus, die sich im Boot-Verzeichnis der gemounteten ISO-Datei befindet. (hier Laufwerk sr0) und selektiert alles so wie auf dem Screenshot. Mein USB-Stick wurde an die virtuelle Maschine als Laufwerk sdb durchgereicht. Anschließend wird eine "Frugal"-Installation durchgeführt und der Inhalt des gesamten USB-Sticks überschrieben.
Die folgenden Installationsschritte können wie in der Voreinstellung beibehalten werden. Lediglich als Dateisystem sollte ext2 gewählt werden, um zusätzliche Schreibvorgänge auf den USB-Stick zu vermeiden, die bei Journaling-Dateisystemen wie z.B. ext3 und ext4 auftreten.
Nach einer weiteren Bestätigung wird daraufhin TinyCore auf den USB-Stick geschrieben. Mit Hilfe des ausgezeichneten Plop Bootmanagers lässt sich dann mit dem Thinkpad 600 TinyCore von USB starten.
Probleme und To-Do
Mit TinyCore auf USB bootet der Thinkpad 600 ohne Probleme. Problematisch ist aber der verwendete XVesa-Treiber, der zwar die Auflösung mit 1024x768 korrekt einrichtet, die Darstellung jedoch grünlich verzerrt, so dass sich praktisch nichts erkennen lässt. Ich muss hier in Zukunft einen Weg finden, um XVesa in Einklang mit meiner MagicGraph-Grafikkarte zu bringen oder TinyCore mit dem X-Server von Xorg zu remastern. Da ich sowieso zusätzliche Erweiterungen installieren möchte, komme ich um das Remastern nicht herum. TinyCore auf einen USB-Stick zu installieren war einfach. Die Konfiguration kann aber unter Umständen länger dauern.
Ich bin erst vor ca. 3 Monaten auf apt-listbugs aufmerksam geworden, obwohl ich seit längerer Zeit auf verschiedenen Rechnern Debian Unstable benutze. Mir war nicht sofort klar, wie das Programm funktionieren würde und ob ich es explizit aufrufen musste, um potentiell fehlerhafte Pakete zu finden. Tatsächlich ist es äußerst einfach damit umzugehen. Man installiert es und fertig. Jedesmal wenn ich ein Update mit Debian mache, überprüft apt-listbugs automatisch, ob im Bug Tracking System bei Debian ein schwerwiegender Fehler zu einem Paket gemeldet worden ist. Falls dies der Fall ist, gibt es eine Warnmeldung und die Abfrage, ob man das neue Paket wirklich installieren möchte. Bisher hatte ich zwei Erfahrungen gemacht. Entweder der gemeldete Fehler war nicht von so schwerwiegender Natur und ich konnte ihn ignorieren oder aber apt-listbugs konnte mir den Fehler nicht melden, weil er nicht im neuen Paket auftrat, sondern sich in einem schon installierten befand, aber erst wirksam wurde nachdem ich die neue Software installiert hatte. Der letzte Fall war auch das Problem bei dem weitläufigen Nvidia Bug und Xorg 1.11, der nicht nur mich, sondern eine Reihe anderer Leute auch betraf. Leider wurde die angestoßene Diskussion auf debian-devel nicht fortgeführt. Hier gäbe es sicher noch Verbesserungspotential. Also alles Mist? Überhaupt nicht. Vor wenigen Tagen rettete mich apt-listbugs vor der Installation von Chromium 15. Das Paket war komplett unbrauchbar, so dass Chromium rein gar keine Webseite mehr darstellen wollte. In diesem Fall entschied ich mich bei meinem alten Chromium 14 zu bleiben und besser auf die Fehlerbehebung zu warten. Wer also viel mit Debian Sid oder sogar Experimental zu tun hat, dem kann ich apt-listbugs auf jeden Fall empfehlen. Es ist zwar nicht perfekt, aber es schützt einem mit Sicherheit vor der ein oder anderen brenzligen Situation.
Es ist ein wunderschöner Morgen, der frisch gebrühte Kaffee dampft aus meiner schwarzen Tasse, die Sonne scheint, die Vögel zwitschern und ich vergnüge mich mit dem Anblick des brandneuen Gnome-3-Desktops von Debian. Das Glück könnte nicht schöner sein und schon beginne ich mit dem wiederkehrenden Ritual eines Systemupdates.
aptitude update aptitude safe-upgrade
Keine berauschenden Neuheiten dieses mal, aber es kann auch nicht immer der 08. November sein. Doch was ist das? Zwei libwebkitgtk-Pakete wollen sich nicht per safe-upgrade installieren lassen. Unerschrocken versuche ich es mit einem full-upgrade. Schon erwarte ich, dass irgendein Paket endgültig deinstalliert werden muss, um das Update zu ermöglichen, doch nein, Apt signalisiert nur die zusätzliche Neuinstallation der zwei Pakete. Dann beginnt der Spaß.
Dpkg meldet mir gleich zwei gzip-Lesefehler und aptitude verabschiedet sich danach mit einem "segmentation fault (core dumped)"-Fehler. Die ZSH-Shell macht es kurz und drückt mit einem Emoticon meine momentane Stimmung aus. 🙁 Weitere Versuche die Pakete zu installieren schlagen fehl. Geistesgegenwärtig mache ich noch einen Screenshot für den späteren Debian-Fehlerbericht. Hier wurde ja offensichtlich gemurkst! Ich versuche Iceweasel zu starten um nach dem Fehler zu recherchieren. Bestimmt gab es noch andere, die das gleiche Schicksal teilten. Iceweasel startet nicht mehr. Ich öffne die Gnome-Shell um eine andere Anwendung zu starten. Gnome-Shell stürzt ab. Wieder mit diesem unglücklichen Emote, dass die Gedanken des Gegenüber nicht besser ausdrücken könnte. 🙁 Fortschritt ist wunderbar. Ich schaue in den Terminal und probiere es mit dmesg.
aptitude[3080]: segfault at 1dcbe0 ip 0828a86e sp bfc33df0 error 4 in aptitude-curses[8048000+3a3000]
[ 527.464217] aptitude[3235]: segfault at 77b3255b ip 0828a88a sp bfd5a920 error 4 in aptitude-curses[8048000+3a3000]
[ 549.243137] gnome-shell[3243]: segfault at b46c0120 ip b5e948ff sp a7c738b0 error 7 in libglib-2.0.so.0.2800.8[b5e33000+f0000]
[ 551.414108] [drm] nouveau 0000:02:00.0: Unexpected pageflip in channel 4.
[ 551.431058] [drm] nouveau 0000:02:00.0: PGRAPH - DATA_ERROR INVALID_BITFIELD
[ 551.431063] [drm] nouveau 0000:02:00.0: PGRAPH - DATA_ERROR
[ 551.431067] [drm] nouveau 0000:02:00.0: PGRAPH - ch 4 (0x0001c70000) subc 5 class 0x8297 mthd 0x1454 data 0x02050185
[ 551.432188] [drm] nouveau 0000:02:00.0: Unexpected pageflip in channel 4.
Mir schwant nichts Gutes und ich beschließe einen Neustart zu machen. Da ich über ein Multiboot-System verfüge, kann ich meine dunklen Vorahnungen sofort überprüfen. Ich boote in mein leichtgewichtiges Debian-Sid-Spielesystem, doch der Rechner hängt sich nach dem Login direkt auf. Bei Ubuntu, meinem dritten System, ereilt mich das gleiche Schicksal. Womit ich einen neuen Vorteil für ein Multiboot-System gefunden habe. Es kann wunderbar als Indikator für Hardwareprobleme dienen. An dieser Stelle bin ich mir schon ziemlich sicher, dass es ins Geld gehen könnte. Ich zögere nicht und greife mir die nächst erreichbare Grml Linuxdistribution und starte aus dem Bootmenü der CD das Programm Memtest86. Memtest gehört zu der Sorte von Programmen, von denen man hofft, dass man sie nie benutzen muss, die aber, wenn es darauf ankommt, extrem hilfreich sind. Ich lasse das Programm 20 Minuten ohne Fehlermeldungen laufen als plötzlich die Anzeige von blau auf rot springt und sich die Fehler beginnen zu summieren. 10000, 20000, 100000....Ich denke, ich bin fündig geworden. Die Warnmeldungen begannen erst in einem Speichersegment > 2GB, weshalb ich die Hoffnung habe, dass der Defekt nur auf einen meiner 2GB RAM Riegel beschränkt ist. Ich öffne das Gehäuse, stelle fest, dass jetzt genau der richtige Moment für eine Reinigungsaktion ist *hust*, entferne Staub und einen der RAM-Riegel (50/50 Chance), verschraube wieder alles, boote erneut mit der Grml-CD und lasse Memtest86 laufen. Ich scheine das richtige Bauteil erwischt zu haben. Zumindest werden mir nun nur noch 12 Fehler angezeigt. Das ist zwar nicht toll, aber immerhin besser als 100000.
Die Moral von der Geschichte
Genauso wie bei Festplattenproblemen ist nicht immer die Software Ursache allen Übels. In den meisten Fällen warnt Linux durch scheinbar beängstigende Fehler bei einem Hardwaredefekt. Ich habe mal wieder gelernt, dass in PCs von der Stange oft Komponenten verbaut sind, die nicht nur günstig, sondern auch billig sein können. Mit Sicherheit achte ich in Zukunft wieder mehr auf Qualität oder zumindest suche ich mir nur noch Hersteller, die auf ihren RAM eine Garantie von 10 Jahren geben, ein Zeitfenster, was gut zu der anderen Hardware des Haushalts passt. Um schnell herauszufinden, welche Art von Speicher überhaupt im eigenen Rechner verbaut worden ist, eignet sich besonders das Standardwerkzeug dmidecode. Mit dem Befehl dmidecode -t memory lässt sich hier genaueres erfahren. Ansonsten scheint alles heil geblieben zu sein. Der Core Duo hat jetzt nur noch 2 GB RAM, aber da ich selten an die 1GB-Speichergrenze stoße, spielt es kaum eine Rolle, ob 3 GB frei sind oder nur 1 GB. 😛
Nachdem ich mein altes Thema Orta für Gnome 3 gefunden hatte, habe ich mich nun doch entschieden vorerst bei Adwaita, dem Standardthema, zu bleiben. Erst bei genauerem Hinschauen erkennt man einige kleine Fehler im neuen Orta-Design und ehrlich gesagt gefällt mir Adwaita einfach besser. Eine Kleinigkeit gab es dann doch noch zu ändern. Die Schriftgröße in der Gnome Shell bei den Anwendungen ist sehr klein geraten. Gerade einmal 7.5pt wurde dafür ausgewählt. Ändern lässt sich diese Einstellung in /usr/share/gnome-shell/theme/gnome-shell.css. Dort muss man zu folgendem CSS Block navigieren und den Parameter font-size von 7.5pt auf z.B. 11pt setzen.
Scheinbar um die Benutzer vor sich selbst zu schützen, haben die Entwickler von Gnome 3 es vorgezogen die alte Löschentaste Entf durch STRG+Entf in Nautilus zu ersetzen. Wer schon immer wissen wollte, wie sich die Tastenkombinationen in Nautilus 3 neu belegen lassen, sollte sich den sehr anschaulich erklärten englischen Blogpost gnome 3 delete key not deleting/working in nautilus nicht entgehen lassen. In Kürze funktioniert das Umändern so:
Die seahorse-plugins waren früher für mich immer der Garant dafür, dass ich mit einem simplen Rechtsklick in Nautilus eine Datei ganz leicht mit GnuPG verschlüsseln oder entschlüsseln konnte. Wie im letzten Beitrag zu Gnome 3 erwähnt, dauert es mit der Wiedereinführung dieses Pakets noch bis Gnome 3.4. Zwar lassen sich die wichtigsten GnuPG-Kommandos auch schnell in der Konsole ausführen, ein grafisches Frontend für die Gnome-Desktopumgebung macht den Umgang mit den vielfältigen Optionen aber deutlich bequemer. Wer nicht warten möchte, hat eine Reihe von Alternativen. Für mich funktionieren die folgenden ganz gut.
Gnu Privacy Assistant (GPA)
Eine Möglichkeit viele Dateien auch mit verschiedenen Schlüsseln bequem mit Hilfe eines grafischen Frontends zu verschlüsseln, bietet das Programm Gnu Privacy Assistant kurz GPA genannt. Im Prinzip lässt es sich wie ein gewöhnlicher Dateimanager bedienen. Zu verschlüsselnde Dateien werden über den "Öffnen"-Dialog importiert, wonach man sie signieren, verschlüsseln und natürlich auch wieder entschlüsseln kann. GPA verwendet dabei die modularisierte und erweiterte Version 2 der GnuPG Software.
Nautilus Actions
Mit der Anwendung Nautilus-Actions lassen sich zusätzliche Menüeinträge zu Nautilus hinzufügen. Sie wird entweder als externes Programm in der Gnome-Shell oder mit dem Befehl nautilus-actions in einem Terminal gestartet. Mit dieser Erweiterung zum Dateimanager Nautilus ist es möglich angepasste Befehle, Funktionen und sogar Skripte an einen Menüeintrag zu binden.
Aktion definieren
Zuerst wird unter dem Reiter Aktion der Kontextbezeichner für den zukünftigen Menüeintrag festgelegt. In diesem Fall also Verschlüsseln oder Entschlüsseln. Zusätzlich lässt sich noch ein Symbol definieren, welches als Miniaturausgabe neben dem Eintrag erscheinen soll.
Befehl festlegen
Um GnuPG bedienen zu können und die Passwortabfrage möglich zu machen, habe ich mich entschieden meinen Terminalemulator rxvt-unicode zu benutzen. Im Prinzip ist es der gleiche "Trick" wie bei den "Benutzerdefinierten Aktionen" in Thunar, den ich im Beitrag zu GnuPG vorgestellt habe. Eigentlich hätte ich erwartet, dass dieses Verhalten standardmäßig von Nautilus-Actions unterstützt wird oder sich zumindest unter dem Reiter Ausführung festlegen lässt. Leider funktionierte das so bei mir aber nicht. Als Pfad trägt man /usr/bin/urxvt oder den für den eigenen Terminal entsprechenden Namen ein und als Parameter dann -e sh -c "gpg -ser 11111111 %f" Dabei muss für 11111111 natürlich euer GnuPG-Schlüsselwert stehen. Die restlichen Einstellungen kann man für "Verschlüsseln" so belassen. Der Eintrag erscheint dann bei jeder Datei und mit einem Klick darauf wird gpg in rxvt-unicode ausgeführt. Dateien werden sowohl signiert als auch verschlüsselt. %f ist der Platzhalter für die Datei.
Entschlüsseln nur für gpg und pgp Dateien anzeigen
Der Parameter für den Entschlüsseln Eintrag im Reiter Befehl sieht bei mir so aus. -e sh -c "gpg -o %w -d %f" Dadurch erhält die entschlüsselte Datei auch wieder ihren Originalnamen (%w). Damit der Eintrag nur bei *.pgp und *.gpg Dateien angezeigt wird, müssen unter dem Reiter Basisnamen und MIME-Typen zwei Filter angelegt und die Option "Muss einem entsprechen" bei beiden ausgewählt werden. Für Basisnamen
*.pgp
*.gpg
Für MIME-Typen
application/pgp
application/gpg
Nützliche Links
Viele vorgefertigte Schemata gibt es auf der Entwicklerseite. Diese lassen sich direkt in Nautilus-Actions importieren. Ebenfalls nützlich ist der Blogeintrag auf upubuntu.com, der Schritt für Schritt mit Bildern zeigt, wie man z.B. den shred-Befehl in das Nautilusmenü einbindet.
Am 08. November 2011 landete schließlich Gnome 3.0 beinahe vollständig (nautilus-dropbox erreichte mich gestern) in Debian Testing und damit auf dem Core Duo. An diesem Tag sollten über 100 Pakete aktualisiert oder installiert werden, wozu ein full-upgrade mit aptitude nötig war. Der ganze Vorgang verlief bei mir vollkommen reibungslos.
Der Post ist etwas ausführlicher geworden als geplant und speziell für Debiannutzer gedacht, die erst seit kurzem mit Gnome 3 konfrontiert werden. Der Beitrag zeigt Alternativen zu Gnome 3 auf, meine ersten Erfahrungen und Schritte mit der neuen Desktopumgebung sowie einige Hinweise zum Entwicklungsstand spezieller Gnome-3-Pakete in Debian. Viel Spaß. Bevor ich nun ein paar Worte über das neue Gnome 3 in Debian Testing verliere, hier gleich das Wichtigste für alle Gnome-2-Fans vorne weg. Solltet ihr längere Zeit kein Upgrade gemacht haben, Vorsicht, Gnome 3 ersetzt Gnome 2 in Testing komplett, eine beschauliche Koexistenz ist leider nicht möglich. Wer auf gar keinen Fall upgraden will hat folgende Optionen zur Hand:
Lang lebe Gnome 2!
Debian Squeeze. Wer ohne das richtige Gnome 2 nicht leben kann, hat nur eine ernsthafte Alternative (ist alternativlos sozusagen) - der Wechsel zu Debian Stable. Was Debian immer von allen Desktopbenutzern angekreidet bekommt, entpuppt sich hier als zusätzliche Stärke. Die Gnomepakete sind nicht etwa veraltet, sondern genau auf dem Stand (2.32), woran Milliarden von Menschen beinahe 10 Jahre lang gearbeitet haben. Und das Beste: Gnome 2 wird noch mindestens bis 2013 unterstützt und wer sich dann weigert ein Upgrade zu machen, kommt noch einmal für ein weiteres Jahr in den Genuss von Gnome 2 in Oldstable Squeeze. Sprich Support und Sicherheitsaktualisierungen bis 2014. Außerdem wird es keine Gnome-3-Backports für Squeeze geben. Denkt darüber nach.
Den Ausweichmodus benutzen. Na gut, es gibt doch ein paar Alternativen. Gnome 3 wird mit einem sogenannten Ausweichmodus ausgeliefert, der dazu gedacht ist Leuten mit Hardware- oder Treiberproblemen dennoch eine grafische Desktopumgebung zur Verfügung zu stellen. Praktischerweise bietet Debian direkt beim Login mit Hilfe von GDM3 die Möglichkeit sich zwischen dem neuen Gnome und diesem Fallbackmodus zu entscheiden. Dieser sieht dem alten Gnome 2 verblüffend ähnlich und lässt sich über das Gnome Tweak Tool (dazu später mehr) auch optisch über Themen anpassen.
Eine andere Desktopumgebung muss her. Wenn dich das alles nicht überzeugt hat und du bei Debian Testing/Sid bleiben willst, kommt nur der Wechsel der Desktopumgebung in Frage, was bei auf Debian-basierenden Systemen nicht schwierig zu verwirklichen ist. Als Alternativen bieten sich hier natürlich Xfce, zumindest solange die Entwickler nicht die Xfce-Shell einführen, und LXDE an. Solltest du dich für letzteres entscheiden liegt ein selbst zusammengestelltes System mit Openbox, Fluxbox oder Awesome nicht weit entfernt und da du schon Testing oder Unstable benutzt, hast du sicherlich nichts gegen Experimente und bist flexibel.
Bringt mir ein Gebüsch Gnome 3
Im folgenden möchte ich speziell zu den Erfahrungen bei der Umstellung von Gnome 2 zu Gnome 3 mit Debian Testing schreiben und aus meiner Sicht erklären, was nun anders ist und wie mein "Workflow" mit der neuen Desktopumgebung funktioniert. Nachdem das Upgrade vollendet war, startete ich den X-Server mit invoke-rc.d gdm3 restart neu und befand mich danach im sogenannten Ausweichmodus von Gnome 3.
3D Support aktivieren
Das Problem war, dass ich zur Zeit wegen eines Bugs im Nvidia-Treiber, der übrigens in Sid nun behoben ist, die Nouveau-Treiber verwende. Die Freien Treiber verfügen zur Zeit größtenteils nur über einen experimentellen 3D-Support, den man bei Debian erst durch das Installieren des Pakets libgl1-mesa-dri-experimental vollständig für meine Geforce 9600GT aktivieren konnte. Gleichzeitig muss man sicherstellen, dass die alten Nvidia-Pakete hier nicht dazwischenfunken. Der sicherste Weg ist alle installierten Nvidia-Pakete zu deinstallieren. Finden lassen sie sich z.B. mit dem Kommando aptitude search 'nvidia ~i'. Startet man danach den X-Server neu, lässt sich Gnome 3 problemlos mit den Freien Nouveau-Treibern bedienen.
Was ist deine Lieblingsfarbe? - Gnome-3-Aussehen anpassen
Gnome 3 ersetzt wie schon gesagt das alte Gnome 2. Das schließt mit ein, dass man an einigen Stellen beim Aussehen Hand anlegen muss.
Anfangs ist noch das Standardhintergrundbild von Debian eingerichtet. Dieses lässt sich aber schnell mit einem Klick auf den Benutzernamen oben rechts -> Systemeinstellungen -> Hintergrund ändern. Auch Icons und das Thema entsprechen den Default-Einstellungen. Um zum alten Aussehen des Gnome 2 Desktops, wie auf den obigen Screenshots gezeigt, zurückzukehren, habe ich zuerst das Gnome-Tweak-Tool installiert, welches dafür da ist "fortgeschrittene" Einstellungen wie Schriften und Thema des Desktops zu ändern, die für den "gewöhnlichen" Benutzer nicht von Interesse seien, so die Beschreibung des Pakets. Das GUI-Fenster des Tweak-Tools lässt sich in Version 3.0 nicht richtig skalieren. Der Fehler läuft bei Debian unter #648005 und ist in Version 3.2 behoben. Mein Icon-Thema ist das ausgezeichnete Faenza, welches sich auf gnome-look.org herunterladen lässt. Am besten man kopiert es nach /usr/share/icons für alle Benutzer oder lokal nach ~/.icons. Als Thema habe ich mit Gnome 2 Orta benutzt. Für die Gnome Shell gibt es eine angepasste Version auf deviantart.com. Das Thema kann im Allgemeinen nach ~/.themes für den lokalen Benutzer und nach /usr/share/gnome-shell für alle User entpackt werden. Bei mir führte die lokale Variante zu Problemen und erst nach der Installation in /usr/share/gnome-shell/theme/ funktionierte alles. Der "theme"-Ordner sollte vorher noch gesichert werden, falls man später zum Default-Thema zurückwechseln möchte. Icons, Themen und Schriften lassen sich nach der Installation dann mit dem Tweak-Tool auswählen. Solange die "Extensions" zur Gnome-Shell in Debian nicht verfügbar sind, kann man das Thema der Shell mit dem gconf-editor ändern. Dort muss man nach desktop->gnome->shell->windows suchen und die Variable theme auf z.B. Orta setzen. Ich war mit der Deckkraft der Gnome-Shell bei diesem Thema noch nicht zufrieden. Veränderungen lassen sich bei Gnome 3 aber über CSS Dateien vornehmen. Um das Hintergrundbild deutlicher hervorzuheben, habe ich die entsprechende Stelle in der gnome-shell.css von Orta angepasst. Die letzte Zahl bei background-color löst das Problem.
Um den Prozess der Desktopgestaltung zu vereinfachen, gibt es Upstream das Feature Erweiterungen zur Gnome Shell zu implementieren. Das entsprechende Paket wird demnächst in Debian Experimental eingestellt. Der Vorgang lässt sich unter Bug #627515 verfolgen. Michael Biebl, einer der Gnome-Betreuer bei Debian, stellte vor wenigen Tagen auf der "pkg-gnome-maintainers"-Mailingliste einen baldigen Upload in Unstable in Aussicht. Mit den Extensions lässt sich nicht nur das Thema intuitiv ändern, sondern auch kontroverse Einstellungen wie die nicht sichtbare "Ausschalten"-Funktion verändern. Ausschalten lässt sich der Computer direkt nur, indem man auf den Benutzernamen oben rechts im Panel klickt und dann die ALT-Taste gedrückt hält, wonach die Funktion erscheint. Ich weiß. 🙄
Unico Engine
Gnome 3 anzupassen bleibt auf jeden Fall ein spannendes Thema. Es gibt z.B. das Projekt Unico, mit dem eine Engine entwickelt werden soll, mit der sich ansprechendere Themen mit Hilfe von GTK und CSS erschaffen lassen. Vielleicht so etwas wie das Gegenstück zur Murrine Engine bei Gnome 2. Bei Debian wartet das Paket noch auf die Aufnahme. Viele sehr gut bewertete Gnome 3 Themen basieren mittlerweile auf Unico, welches sich mit Ubuntu schon ausprobieren lässt.
Wie man die Heilige Handgranate bedient - Gnome 3 Workflow
Die Dash
Kurzum für mich hat sich nicht besonders viel verändert. Früher benutzte ich entweder das Panel oder das AWN-Dock um oft verwendete Anwendungen schnell starten zu können. Anwendungen lassen sich nun nicht mehr auf das Panel ziehen. Diese Funktion ist tatsächlich überflüssig geworden. Die Funktion des AWN-Docks übernimmt die Dash, welche anstatt am unteren Bildschirmrand nun auf der linken Seite angebracht ist. Hervorholen lässt sie sich mit der Super/Windows-Taste oder durch die Bewegung des Mauscursor in die obere linke Ecke. In der Regel habe ich nur eine Handvoll von Anwendungen, die ich wirklich oft brauche und die Dash spart mir hier sogar noch mehrere zusätzlich installierte Pakete.
Die Shell
Früher gab es die simple Aufteilung Anwendungen/Orte/System. Jeder wusste sofort, wo er was suchen musste. Heute lassen sich die Anwendungen direkt über die Shell suchen, die mit der Super-Taste geöffnet wird. Man kann entweder den gesuchten Programmnamen eintippen, die Anwendung mit den Pfeiltasten auswählen und das Ganze bestätigen. Oder man navigiert mit der Maus im rechten Anwendungsmenü, welches wahrscheinlich nicht ganz zufällig Erinnerungen an Gnome 2 Zeiten weckt. Wie man es nimmt, Programme zu finden ist mit Gnome 3 kein bisschen schwieriger als früher. Gnome 3 ermutigt einen auch regen Gebrauch vom Arbeitsflächenumschalter auf der rechten Seite zu machen. Ich finde es am einfachsten die wichtigsten Programme wie z.B. Browser oder E-Mail-Anwendung auf eine separate Arbeitsfläche zu verschieben und dann mit STRG+ALT+Pfeiltaste oder ALT+TAB zwischen ihnen zu navigieren. Zwar lassen sich die alten Minimierung/Maximierung-Symbole mit dem Tweak-Tool wieder hervorholen, wenn man sich aber auf die Gnome-3-Philosophie einlässt, muss man diese Einstellung nicht in Frage stellen. Fenster müssen nicht zwangsläufig minimiert werden um Übersicht zu schaffen.
Ein kleines Fazit
Ich denke das Konzept von Gnome 3 ist schlüssig, wenn man davon ausgeht, dass der "normale" Anwender nur eine Handvoll von Programmen regelmäßig benutzt und dieser eine größtmögliche Übersichtlichkeit über laufende Anwendungen haben möchte. Die Statusanzeige am unteren Bildschirmrand, welche dezent verborgen ist, ist meiner Meinung nach gut gelungen. Diese Art von Anzeige muss auch nicht unbedingt im Panel erscheinen. Im Moment stört mich nur die eingeschränkte und meiner Meinung nach auch benutzerunfreundliche Konfiguration von Desktopeinstellungen und der Themen. Diese Probleme werden aber schon bald ausgeräumt werden. Man sollte auch immer im Hinterkopf behalten, dass Gnome 3 noch am Anfang des Entwicklungszyklus steht. Gnome 2 brauchte auch 8-9 Jahre bis es vollständig gereift war. Das neue Gnome 3 ist definitiv anders als alle anderen Desktopkonzepte. Man kann ihm nicht vorwerfen, dass es irgendwo abgekupfert hätte. Gerade für den sogenannten Arbeitsplatzrechner halte ich Gnome 3 für geeignet. Compizfunktionen vermisste ich bei den getroffenen Designentscheidungen nicht. Kontrovers werden auch die Entscheidungen in Debian diskutiert, warum das Metapaket gnome-core das Bluetooth-Paket als Abhängigkeit besitzt oder ob es zwingend notwendig sein muss, dass der Network-Manager immer installiert ist und dabei teilweise andere Netzwerkeinstellungen ignoriert. Nachlesen lässt sich der Thread auf der debian-devel Mailingliste.
Ausblick
Schon Gnome 3.2 bringt wieder einige Verbesserungen in Debian mit sich. Wie der aktuelle Stand von 3.2 ist lässt sich nach wie vor hier erfahren. Ich hoffe, dass bald auch wieder eine Verschlüsselungsfunktion in Nautilus mit Hilfe von Seahorse integriert sein wird. Das frühere Paket seahorse-plugins wurde komplett aus Debian auf Grund schwerwiegender Fehler entfernt. Laut den Seahorse Entwicklern ist eine Wiedereinführung für Gnome 3.4 geplant. Zum Schluss das Wichtigste: Am besten Gnome 3 selbst installieren und sich eine eigene Meinung bilden. 😉