GNU Hurd ist ein in Assembler und C geschriebener Kernel (Betriebssystemkern) mit einem Mikrokernel als Basis.[2] Dieser implementiert Dateisysteme, Netzwerkprotokolle, Datei-Zugriffskontrollen und andere Eigenschaften. Die Entwicklung des Kernels begann bereits 1990. Die zur Entwicklung geschaffene GNU Compiler Collection (gcc) hat große Verbreitung gefunden.
GNU Hurd | |
---|---|
HURD-Live-CD-Login | |
Entwickler | Thomas Bushnell, Roland McGrath, Marcus Brinkmann, Neal Walfield |
Lizenz(en) | GNU GPL |
Akt. Version | 0.9[1] (18. Dezember 2016) |
Kernel | Mikrokernel |
Abstammung | Unix ↳ GNU Hurd |
Architektur(en) | IA-32 |
Sprache(n) | multilingual |
Sonstiges | In Entwicklung |
www.gnu.org/software/hurd/ |
Konzept
Hurd verwendet GNU Mach, eine Weiterentwicklung des Mach-Mikrokernels der letzten Version 4 von 1996.[3] 2002 wurde versucht, Hurd auf den L4-Mikrokernel zu portieren, dieses Vorhaben wurde jedoch 2005 wieder aufgegeben.[4]
Nach der Portierung von Java auf GNU Hurd im Rahmen des Google Summer of Code (2011) wurde diskutiert, den Systemkernel in Debian Wheezy aufzunehmen. Die Idee wurde jedoch später verworfen.[5][6]
Die Betriebssystem-Komponenten von Hurd laufen als eigene Prozesse (englisch server genannt). Durch das Design von GNU Hurd benötigen die meisten Betriebssystem-Aktionen keinerlei Privilegien mehr. Das wird erreicht, indem Gerätetreiber, Dateisysteme, Netzwerkprotokolle und Ähnliches aus dem privilegierten Adressraum des Systemkernels herausgenommen werden und als normale Benutzerprozesse laufen, sodass sie (theoretisch) keinen Schaden am Gesamtsystem anrichten können.
Ein Prozess kann allerdings besondere Privilegien erhalten, um besondere Betriebssystem-Funktionen durchführen zu können. Dieses Konzept bietet eine Reihe von Vorteilen:
- Sollte ein Prozess in seinem Dienst versagen, kann er den Kernel nicht ohne weiteres zum Erliegen bringen.
- Programme im User-Space sind leichter zu debuggen.
- Sofern nicht bestimmte Privilegien benötigt werden, kann jeder Benutzer selbst Betriebssystem-Komponenten setzen, um zum Beispiel ein eigenes Dateisystem einzurichten. Da die entsprechende Betriebssystem-Komponente dann unprivilegiert läuft, stellt sie kein Sicherheitsrisiko dar. Außerdem braucht der Benutzer nicht die eingebauten Funktionen des Kernels zu benutzen, sondern kann sich den Dienst selbst nach Belieben erstellen, ohne dass die Integrität des Systems dadurch in Mitleidenschaft gezogen werden kann.
Sogenannte Übersetzer beantworten Zugriffsanfragen auf einen Einhängepunkt. Dieser kann eine einzelne Datei oder eine ganze Verzeichnis-Hierarchie im Dateisystem sein. Dadurch können Programme auch ohne spezielle Anpassungen mit den üblichen Dateioperationen von den Möglichkeiten von Hurd profitieren. Sinnvoll ist das beispielsweise für Low-Level-Implementierungen virtueller Dateisysteme: Der Übersetzer FTPFS stellt zur Laufzeit auf der zugewiesenen Datei ein Verzeichnis dar (der Unterschied zwischen Dateien und Verzeichnissen ist in Hurd sehr gering), auf das wie auf ein normales Verzeichnis zugegriffen werden kann; allerdings übersetzt ftpfs die Dateioperationen in FTP-Operationen, die zu einem Server geschickt werden. Das entspricht im Wesentlichen der Funktionalität graphisch orientierter FTP-Clients, in denen entfernte Verzeichnisse wie lokale aussehen, ftpfs von Hurd ermöglicht es jedoch, mit normalen Programmen wie ls oder cat auf dem entfernten Server zu agieren.
GNU-Hurd-Distributionen
Namensbedeutung
Bei dem Namensteil Hurd (früher auch HURD) von GNU Hurd handelt es sich um ein komplexes rekursives Akronym, nämlich ein (zweistufig) indirektes, das in der ersten Auflösung HIRD of Unix-Replacing Daemons (deutsch: „Herde Unix-ersetzender Dienste“) lautet. HIRD wird wiederum zu HURD of Interfaces Representing Depth (deutsch: „Herde Tiefe-darstellender Schnittstellen“) aufgelöst. Obige Übersetzung ist keine exakte, sondern gibt die Bedeutung der beiden Kunstworte assoziativ bzw. auf einer lautmalerischen Ebene wieder, denn sie basiert nur auf dem gleich (hier: nicht generell ununterscheidbar) ausgesprochenen engl. Wort herd (deutsch: Herde). Durch die Akronyme und die lautmalerische Verfremdung werden zwei unter Hackern übliche Traditionen gleichzeitig genutzt.
Versionen
- Am 4. Mai 2013 wurde mit Debian GNU/Hurd eine Version von Debian mit GNU Hurd als Kernel veröffentlicht. Diese Debian-Version entsprach dem damals aktuellen Unstable-Release (Codename „Sid“) von Debian GNU/Linux mit etwas reduziertem Paket-Umfang.[7] Sie umfasste mit etwa 10.000 Paketen 75 % der Linux-Version.[8][9] Die darauffolgende Version von GNU Hurd vom September 2013 erhielt die Versionsnummer 0.5.[10]
- Die Ausgabe 0.6, die am 15. April 2015 veröffentlicht wurde, unterstützt das virtuelle Dateisystem Procfs. Zudem wird nun ein Sys-V-ähnliches Startprogramm genutzt.[11][12]
- Am 31. Oktober 2015 erschien Version 0.7 mit verbessertem Festplattencache; auch fakeroot wurde verbessert. Das Programm rpcscan hilft, Mikrokernel-Prozesse, die Systemdienste anbieten, zu suchen und anzuzeigen, welche Remote Procedure Calls sie gerade verarbeiten. Zwischen Dateisystem-Translatoren, libdiskfs und libpager behob man Synchronisationsprobleme.[13]
- Version 0.8 erhielt am 18. Mai 2016 neue und aktualisierte Bibliotheken (netfs, Integer-Hashing-Library, hurd-slab). Sie nutzt die neue Mach-Version 1.7.[14]
- Version 0.9 erschien am 18. Dezember 2016 und verwendet Mach 1.8. Neben Fehlerkorrekturen wurde ein Ethernet-Multiplexer für virtuelle Interfaces sowie der Paketfilter libpf (die Berkeley Packet Filter Library) hinzugefügt.[15]
- Im vierten Quartal 2018 wurde der Zugriff auf PCI-Karten verbessert und der lwIP (ein leichtgewichtiger TCP-/IP-Netzwerkstack) und das ACPI (Advanced Configuration and Power Interface) aktualisiert.[16]
- Aktuell (Stand: Juli 2019) wurden etwa 80 % des Paket-Umfangs des aktuellen Unstable-Release von Debian portiert.[17]
Siehe auch
Weblinks
- GNU HURD: Veränderte Visionen und verworfene Versprechen. heise open vom 28. Juli 2010
- GNU/Hurd, die Geschichte ohne Ende, Heise online vom 10. November 2002, zum geschichtlichen Hintergrund
Einzelnachweise
Wikiwand in your browser!
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.