RPM Package Manager

Paketverwaltung von Red-Hat-basierenden Distributionen

RPM Package Manager ist ein freies (GPL) Paketverwaltungs-System, ursprünglich entwickelt von dem Unternehmen Red Hat. Es umfasst das Paketformat und alle nötigen Programme, um RPM-Pakete zu erstellen und zu verwalten.

RPM Package Manager

Logo von RPM Package Manager
Basisdaten

Entwickler Panu Matilainen
Erscheinungsjahr 1997[1]
Aktuelle Version 4.20.0[2]
(7. Oktober 2024)
Betriebssystem Unixartige Systeme wie bspw. GNU/Linux und OS/2/eComStation
Programmier­sprache C
Kategorie Paketverwaltung
Lizenz GPL (Freie Software)
deutschsprachig ja
rpm.org

Das RPM-Format ist Teil der Linux Standard Base und bedeutet RPM Package Manager, früher Red Hat Package Manager.

Hintergrund

Bearbeiten

In der Frühzeit von Linux waren die .tgz-Pakete gang und gäbe; eine automatisierte Verwaltung war mit ihnen kaum möglich. Abhängigkeiten wurden weder aufgelöst, noch wurde zumindest eine Warnung ausgegeben. Anwender, die Software installieren wollten, mussten entweder genug wissen, um diese Abhängigkeiten selbst aufzulösen, oder installierten einfach alle Pakete, was aber wiederum die Gefahr von Paketkonflikten mit sich brachte.

Gewisse Ansätze einer Paketverwaltung gab es, als in Anlehnung an die großen Paketverwaltungen der etablierten Unix-Systeme dieser Zeit – wie SunOS (ein Vorläufer von Solaris), HP-UX, OSF/1, IRIX oder Apollo Domain/OS – erste Werkzeuge entwickelt wurden, die jedoch nur wenige Funktionen mitbrachten.

Dies verursachte den Linux-Distributoren dieser Zeit erhebliche Probleme beim Support und bei der Pflege ihrer Software, woraufhin zwei konkurrierende Systeme entwickelt wurden: das Debian-Paketmanagement dpkg für Debian-Pakete, initiiert vom Debian-Projekt, und RPM von Red Hat.

Das Ziel war es, Softwarepakete genauso für den Entwickler wie auch für den Anwender einfacher handhabbar zu machen, Abhängigkeiten sollten berücksichtigt und möglichst automatisch aufgelöst werden. Redundanzen wie doppelte Dateien oder Verzeichnisse sollte das System vermeiden, und es sollte möglich sein, Software sauber zu deinstallieren und dabei Abhängigkeiten zu beachten. Auch sollte es möglich werden, Software einfach zu aktualisieren und Konfigurationsdateien sicher zu verwalten.

Eine Funktion zur Rückabwicklung bei Fehlern (Transaktionen und Rollback) ist inzwischen ebenso Bestandteil von RPM wie bei den großen Paketverwaltungen von HP-UX und Solaris, wenn auch noch nicht in gleichem Umfang.

Geschichte

Bearbeiten

Die erste 1995 für Red Hat Linux 2.0[3] entwickelte Version von RPM basierte auf RPP, PMS (in den 1990er Jahren von Rik Faith für Linux-Betriebssysteme entwickelt) und PM; sie wurde in Perl geschrieben. Später wurde RPM in C neu geschrieben.

Ursprünglich bedeutete RPM Red Hat Package Management. Ende der Neunziger wurde der Name jedoch in RPM Package Management geändert. Der Hintergrund waren rechtliche Aspekte. RPM wurde inzwischen von vielen Distributoren verwendet, und man strebte die Aufnahme von RPM in die Linux Standard Base an. Der Unternehmensname (Firma) im Namen der Software hätte dies zumindest erschwert.

RPM wurde von zahlreichen Linux-Distributionen, wie z. B. SUSE, Mageia oder Mandriva Linux übernommen. Auch einige Unix-Systeme wie z. B. IBM AIX oder Solaris sowie nicht-unixoide Systeme wie Novell Netware nutzten RPM.

Zwischen 1999 und 2006 kam die Weiterentwicklung der Software praktisch zum Erliegen. Jeff Johnson, der Hauptentwickler von RPM bei Red Hat bis 1999, entwickelte jedoch die Software teilweise weiter und kümmerte sich um Fehlerkorrekturen. Aus diesem Zweig entstand RPM5 als Weiterentwicklung von RPM der Version 4.[4]

Die verschiedenen Distributoren entwickelten in der Zwischenzeit (1999–2006) eigene Patches für RPM, um Fehler zu beseitigen; Johnsons Patches wurden meist nicht verwendet.

Im Dezember 2006 schlossen sich verschiedene Distributoren unter Red Hat und Novell zum RPM-Projekt zusammen und entwickelten RPM mit den jeweiligen distributionseigenen Patches – weiterhin ohne Johnsons Änderungen – gemeinsam weiter.[5]

Daraus resultieren nun zwei Versionen von RPM: RPM mit Patches der Distributoren und RPM5, welches sich als RPM aus der „originalen Codebasis“ bezeichnet.[6]

Da die meisten Linux-Distributionen freie Software sind, besteht der Vorteil einer bestimmten Distribution gegenüber anderen zu einem großen Teil aus den Annehmlichkeiten des jeweiligen Paket-Managers (und aus den zusammengestellten, getesteten und regelmäßig aktualisierten (RPM-)Paketsammlungen des jeweiligen Distributors im Internet). Pakete zwischen Distributoren auszutauschen, war früher nahezu unmöglich. Dies wurde mit RPM einfacher, ist aber immer noch mit Problemen behaftet, da die verschiedenen Distributionen, die RPM benutzen, oft verschiedene Versionen und/oder Konfigurationen von Systemsoftware wie etwa Grafik-Bibliotheken verwenden.

Für den Entwickler vereinfacht ein Paketverwaltungssystem wie RPM das Einbauen von Software in die durch die Distribution vorgegebene Struktur (Pfade, Abhängigkeiten, Dateinamen, Paketnamen). Das Paketformat selbst überprüft allerdings den jeweiligen Inhalt eines Pakets nicht automatisch. Der Entwickler bestimmt den Aufbau des Paketes selbständig und muss sich damit für jede Distribution in die jeweiligen Besonderheiten einarbeiten.

Mit Einführung der Linux Standard Base wurden viele Unstimmigkeiten zwischen den Distributoren ausgeräumt. LSB erleichtert die Arbeit der Paketbauer erheblich, weil zumindest Dateinamen und Pfade vereinheitlicht sind. Entsprechende Sorgfalt des Paketmaintainers vorausgesetzt, lässt sich relativ sicher ein RPM von einem anderen LSB-Distributor in ein beliebiges anderes LSB-System einspielen.

Portierungen

Bearbeiten

Eine Paketverwaltung ist systemabhängig. So besitzen außer verschiedenen Distributoren nicht mal alle Linuxanbieter das gleiche Paketformat. Andere Systeme bringen natürlich ihre eigene Software mit.

Da aber auf vielen anderen Unix-Systemen mittlerweile die GNU-Software zur Grundausstattung gehört (zumindest installiert der Systemverwalter sie in der Regel ganz schnell nach) wurde auch RPM – vor allem im Rahmen des Projektes OpenPKG – auf andere Systeme portiert, wodurch man einfach zusätzliche Software einspielen kann.

In gewissem Sinn ist dies gleichermaßen ein Fortschritt und ein Rückschritt. Bisher haben Systemverwalter aus den Quellen die Software selber kompiliert und dann in das System eingepflegt. Dieser Schritt und die damit angefallene Arbeit entfallen natürlich.

Allerdings gibt es zwischen der Paketdatenbank von RPM und der systemeigenen Paketdatenbank keine Kommunikation, und somit werden doppelte Installationen genauso wenig aufgelöst wie fehlende Systemabhängigkeiten über die Paketsysteme hinweg.

Für OS/2 bzw. ecomstation wurde das System auch portiert,[7] so dass es sich inzwischen nicht mehr nur auf unixartige Betriebssysteme beschränkt.

Die RPM-Dateien sind in der Regel mit gzip oder LZMA[8] (xz) komprimierte cpio-Archive, die einzelnen Teile können jedoch einfach nach bestimmten Informationen durchsucht werden, denn ein Kopfdatenbereich im Binärformat ist an jedes Paket angefügt. Diese Kopfdaten sind nicht komprimiert und enthalten alle wichtigen Informationen. Das erleichtert das schnelle Durchsuchen von RPM-Paketen.

Entpacken ohne Installation ist möglich: rpm2cpio foo.rpm | cpio -idmv

XML Package Metadata

Bearbeiten

In den RPM-Spezifikationen finden sich ebenfalls die Spezifikationen für Verzeichnisse mehrerer RPM-Pakete. Die Pakete werden dabei in einem Verzeichnis gespeichert, das neben den Paketen noch Informationen über die Pakete selbst in Form von Metadaten-Dateien enthält. Wenn ein geeignetes Programm dann Informationen über die im Verzeichnis enthaltene Software benötigt, reicht es, die Metadaten herunterzuladen. In diesen Daten sind die vorhandenen Pakete, deren Versionen, Abhängigkeiten, Architektur etc. enthalten.

Programme, die XML-Package-Metadaten verwalten können, sind yum, Yast, Red Carpet, smartpm und apt-rpm.

Programme, die RPM-Pakete verarbeiten

Bearbeiten
  • rpm – ein Linux-Programm, das direkt über die Konsole aufrufbar ist.
  • Konsolen-Frontends
  • GUI-Frontends
    • KPackage (KDE)
    • gnorpm (Gnome)
    • Yumex und KYum – zwei grafische Oberflächen für Yum (Gnome; KDE)
    • PackageKit – ein grafisches Programm, das sowohl auf der Basis von APT als auch auf Yum läuft.
    • anpm (ArcaNoaePackageManager) – Frontend für OS2 bzw. eComStation.[9]
    • dnfdragora – eine grafische Anwendung zum Verwalten von RPM-Paketen, welche den Paketmanager DNF benutzt.
  • Maintaining Tools
    • apt4rpm – eine Portierung von APT für das RPM-Format.
    • rpmlint
    • alien – ein Programm, welches RPM-Pakete in Debian-Pakete für Debian (und auf dessen Paketverwaltung aufbauende Distributionen wie Ubuntu), und umgekehrt, konvertiert.
  • Server / Repositories

Betriebssysteme, die RPM nutzen

Bearbeiten

Linux-Distributionen:

UNIX-Systeme:

Andere:

Siehe auch

Bearbeiten
Bearbeiten

Einzelnachweise

Bearbeiten
  1. rpm5.org.
  2. [Rpm-announce] RPM 4.20.0 released! 7. Oktober 2024 (abgerufen am 8. Oktober 2024).
  3. Red Hat history. Red Hat, abgerufen am 25. Oktober 2013 (englisch).
  4. The Story of RPM auf redhat.com, 8. Juli 2007
  5. Pro-Linux, News von 15. Dezember 2006
  6. rpm5.org (Memento des Originals vom 20. August 2007 im Internet Archive)  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/rpm5.org
  7. http://trac.netlabs.org/rpm
  8. Poelstra: XZ (LZMA) Payloads in RPM. Fedora-Projekt, 19. August 2009, abgerufen am 2. Mai 2014 (englisch).
  9. https://www.arcanoae.com/resources/downloadables/