[[Vorlage(Baustelle, 01.10.2012, RedKnight)]] [[Vorlage(Getestet, general)]] {{{#!vorlage Wissen [:Terminal:Ein Terminal öffnen] [:sudo:Root-Rechte] [:Paketverwaltung:] [:Shell:Bedienung des Terminals] }}} [[Inhaltsverzeichnis(1)]] =Übersicht= dpkg dient zum Installieren einzelner '''.deb'''-Pakete. Das Programm stellt das Backend dar, das auch von [:APT/apt-get:apt-get] und [:aptitude:] benutzt wird. =Optionen= Für die meisten Operationen sind Rootrechte[2] nötig. ==Normale Optionen== dpkg erfordert die Angabe der Option, was die auszuführende Operation angibt sowie abhängig von der Option die Angabe eines Paketnamens oder des Pfades zu einem '''.deb'''-Paket. {{{#!vorlage Tabelle <-3 rowclass="titel"> Kommandozeilenoptionen zu dpkg +++ Kürzel Lange Option Beschreibung +++ `-i` `--install` Installiert das als Argument übergebene '''.deb'''-Paket (Dateiname oder mit Option `-R` Ordnername). +++ `--configure` Versucht die Installation von noch nicht fertig konfigurierten Paketen zu beenden. Entweder können die Paketnamen als Argumente übergeben werden oder es wird die Option `-a` bzw. `--pending` angegeben, um alle noch zu konfigurierenden Pakete zu verarbeiten.[[BR]]Soll ein bereits korrekt installiertes Paket erneut konfiguriert werden, muss [:dpkg-reconfigure:] genutzt werden. +++ `-r` `--remove` Entfernt das als Argument übergebene genannte Paket. Wichtig: Der Name des Pakets, nicht der Dateiname muss angegeben werden. Eventuell vom Programm angelegt Konfigurationsdateien bleiben erhalten. +++ `-l` `--list` Ruft [#dpkg-query dpkg-query] auf und gibt eine Liste mit Status, Version und einer Kurzbeschreibung des Pakets aus. Statt des Namens kann auch ein regulärer Ausdruck angegeben werden. Wird kein Argument übergeben, werden alle Paketstatus aufgelistet. Diese Option ist auch für unterprivilegierte Nutzer verfügbar. +++ `-P` `--purge` Entfernt das genannte Paket inklusive der Konfigurationsdateien. +++ `-R` `--recursive` Statt eines Pfades zu einer '''.deb''' kann mit `-R` auch ein Verzeichnis angegeben werden, die gewählte Operation wird dann auf alle Pakete im Verzeichnis angewandt. +++ `-L` `--listfiles` Ruft [#dpkg-query dpkg-query] auf und gibt eine Liste der im Paket enthaltenen Dateien aus. +++ `-S` `--search` Ruft [#dpkg-query dpkg-query] auf, um auszugeben in welchen Paketen sich Dateien befinden, die zum angegeben Suchmuster passen. }}} Eine vollständige Liste der Optionen findet sich in der '''dpkg'''(1) [:Manpage:] im Abschnitt `ACTIONS` bzw. `AKTIONEN`. ==force Optionen== {{{#!vorlage Warnung Diese Optionen können die Paketverwaltung und das System irreparabel beschädigen. Deswegen sollten diese Optionen nur mit äußerster Vorsicht und ausreichendem Verständnis angewandt werden. }}} In Ausnahmefällen kann es nötig sein, die Fehler zu übergehen, die dpkg zum Anhalten zwingen. Force-Optionen lassen sich mit den gewöhnlichen Optionen kombinieren, wo es sinnvoll ist. {{{#!vorlage Tabelle <-2 rowclass="titel"> Kommandozeilenoptionen mit force +++ Lange Option Beschreibung +++ `--force-help` Gibt eine Liste der force-Optionen mit einer Kurzbeschreibung aus. +++ `--force-depends` Ändert Abhängigkeitsfehler zu Warnungen. Ein Paket kann so trotz fehlender Abhängigkeiten installiert werden. [:Paketverwaltung/Problembehebung#Es-werden-kaputte-Pakete-gemeldet:`apt-get -f`] wird eventuell zur Korrektur benötigt. +++ `--force-architecture` Erlaubt die Installation eines Pakets, das nicht zur Architektur passt. Nützlich, um reine 32-Bit-Pakete auf einem 64-Bit-System zu installieren. Allerdings ist meist die [ubuntu:MultiarchSpec:Multiarch]-Integration des Paketes fehlerhaft und die für das Paket Verantwortlichen sollten darüber informiert werden. +++ `--force-remove-reinstreq` Erlaubt das Entfernen eines Pakets, dessen Reinstallation nötig ist. Teile des Paketes können nach dem Entfernen auf dem System verbleiben. }}} Eine vollständige Liste der force-Optionen findet sich in der '''dpkg'''(1) [:Manpage:] im Abschnitt `OPTIONS` bzw. `OPTIONEN`. =Hilfsprogramme= ==dpkg-query== dpkg-query erlaubt Zugriff auf die Paketverwaltungsdatenbank, also auf Metainformationen (Paketstatus, Kontrollfelder, ...). Die Abfrage von Informationen über Paketdateien wird stattdessen über [#dpkg-deb dpkg-deb] geregelt. Einige Optionen können auch direkt mit dem `dpkg`-Befehl angesteuert werden. {{{#!vorlage befehl dpkg-query OPTION PAKET/SUCHMUSTER }}} {{{#!vorlage Tabelle <-3 rowclass="titel"> Kommandozeilenoptionen zu dpkg-query +++ Kürzel Lange Option Beschreibung +++ `-l` `--list` Gibt eine Liste der zum Suchmuster passenden Pakete und deren Informationen aus. +++ `-S` `--search` Gibt aus, in welchen Paketen sich Dateien befinden, die zum angegeben Suchmuster (z.B. Pfad) passen. +++ `-L` `--listfiles` Gibt die im Paket enthaltenen Dateien aus. Das Paket wird über den Paketnamen als Argument übergeben und muss installiert (oder nicht vollständig entfernt) sein. }}} Eine vollständige Liste der Optionen findet sich in der '''dpkg-query'''(1) [:Manpage:] im Abschnitt `COMMANDS` bzw. `BEFEHLE`. == Paketstatus == Zusätzlich zur Kurzbeschreibung des Pakets gibt `--list`/`-l` eine Statusangabe zum jeweiligen Paket aus. Diese besteht aus 3 Stellen: 1. Gewünschter Paketstatus * `u` für unbekannt * `i` für installieren * `h` für halten * `r` für entfernen (Konfigurationsdateien behalten) * `p` für vollständig (inkl. Konfigurationsdateien) entfernen 1. Aktueller Paketstatus * `n` für nicht installiert * `c` für Konfigurationsdateien verbleibend * `H` für nicht vollständig installiert (nicht alle Dateien konnten installiert werden) * `U` für entpackt (vor dem eigentlichen Installieren) * `F` für nicht vollständig konfiguriert (Fehler in Konfigurationsskripten) * `W` für Trigger-Verarbeitung (durch anderes Paket) wird erwartet (Trigger sind z.B. das Aktualisieren des Manpageindexes oder das Aktualisieren der durch [:.desktop Dateien:] bereitgestellten [:MIME-Typ:MIME-Typen], also Vorgänge, die für mehrere Pakete interessant sind. Anstatt diese Vorgänge nach der Installation jedes einzelnen Paketes auszuführen, wird der Vorgang erst am Ende der Installation aller Pakete ausgeführt.) * `t` für Trigger-Verabeitung steht bevor * `i` für installiert 1. Fehler (Leerzeichen für keine Fehler) * `R` für Reinstallation erforderlich So bezeichnet `ii` ein vollständig installiertes Paket, `rc` ein entferntes Paket von dem noch Konfigurationsdateien vorliegen und `un` ein nicht (mehr) installiertes Paket. Eine vollständige Liste der Statusangaben findet sich in der '''dpkg-query'''(1) [:Manpage:] im Abschnitt `PACKAGE STATES` bzw. `PAKETZUSTÄNDE`. ==dpkg-deb== dpkg-deb stellt grundlegende Möglichkeiten zum Packen und Entpacken, sowie die Abfrage von Metainformationen (enthaltene Dateien, Kontrollfelder, ...) von '''.deb'''-Paketen bereit. Einige Optionen können auch direkt mit dem `dpkg`-Befehl angesteuert werden. {{{#!vorlage befehl dpkg-deb OPTION VERZEICHNIS/PAKET }}} {{{#!vorlage Tabelle <-3 rowclass="titel"> Kommandozeilenoptionen zu dpkg-deb +++ Kürzel Lange Option Beschreibung +++ `-I` `--info` Zeigt Informationen des als Argument übergenenen '''.deb'''-Paketen an. Als optionales zweites Argument kann der Name einer (vorhandenen) Kontrolldatei übergeben werden, deren Inhalt dann in der Standardausgabe angezeigt wird. +++ `-b` `--build` Erstellt ein '''.deb'''-Paket aus einem angegebenen Verzeichnis. +++ `-c` `--contents` Zeigt den Inhalt eines '''.deb'''-Pakets an. +++ `-x` `--extract` Entpackt das angegebene '''.deb'''-Paket in das angegebene Zielverzeichnis. }}} Eine vollständige Liste der Optionen findet sich in der '''dpkg-deb'''(1) [:Manpage:] im Abschnitt `COMMANDS` bzw. `BEFEHLE`. ==dpkg-divert== Mit dpkg-divert können Umleitungen eingerichtet werden, sodass z.B. Dateien, die von einem Paket bereitgestellt werden, beim Paketupgrade nicht verändert werden. So kann man nicht nur lokale Änderungen (ohne Verlust) vornehmen, sondern auch Pakete, die Dateien an exakt der selben Stelle installieren, trotzdem parallel installieren (vorausgesetzt die Pakete sind nicht explizit als gegenseitiger Konflikt markiert). {{{#!vorlage befehl dpkg-divert (OPTION) BEFEHL DATEI/MUSTER }}} {{{#!vorlage Tabelle <-2 rowclass="titel"> Kommandozeilenoptionen zu dpkg-divert +++ Befehl Beschreibung +++ `--add` Fügt eine Umleitung für die als Argument übergebene Datei hinzu. Die Angabe von `--add` als Kommando ist optional. Wenn kein Kommando angegeben wurde, wird immer dieses Kommando gewählt. +++ `--remove` Entfernt die Umleitung für die als Argument übergebene Datei. Wenn bei der Umleitung umbenannt wurde, muss trotzdem die ursprüngliche Name übergeben werden. +++ `--list` Listet alle aktuell eingerichteten Umleitungen, die auf das als Argument übergebene Suchmuster passen, auf. Ohne Argument werden alle Umleitungen aufgelistet. +++ <-2 rowclass="highlight"> +++ Option Beschreibung +++ `--local` Richtet die Umleitung so ein, dass die Datei durch kein Paketupgrade und durch keine Paketinstallation verändert wird. +++ `--package` Das als Argument übergebene Paket ist als einziges Paket nicht von der Umleitung betroffen. +++ `--rename` Beim Einrichten (bzw. Entfernen) wird die Datei umbenannt. Standardmäßig wird die Endung '''.distrib''' hinzugefügt (bzw. entfernt). Existierende Dateien werden nicht überschrieben, eher bricht die Umbenennung ab. +++ `--test` Es werden keine Änderungen vorgenommen. }}} Eine vollständige Liste der Befehle und Optionen findet sich in der '''dpkg-divert'''(8) [:Manpage:] im Abschnitt `COMMANDS` und `OPTIONS` bzw. `BEFEHLE` und `OPTIONEN`. =Beispiele= ==Installation== {{{#!vorlage befehl sudo dpkg -i /PFAD/ZUM/PAKET/PAKET.deb }}} Installiert das `PAKET` im genannten Pfad. ==Entfernen== {{{#!vorlage befehl sudo dpkg -r vim }}} Entfernt das Paket '''vim'''. {{{#!vorlage befehl sudo dpkg -r vim* }}} Entfernt alle Pakete, deren Name mit `vim` beginnt. ==Anzeige== {{{#!vorlage befehl dpkg -l vim* }}} Gibt die Informationen zum allen Paketen aus, deren Name mit `vim` beginnt. Oft macht es Sinn die Ausgaben z.B. mit [:grep:] nach den [#Paketstatus Paketstatus] zu filtern. ==Konfiguration beenden== {{{#!vorlage befehl sudo dpkg --configure -a }}} Führt alle noch ausstehenden Konfigurationsskripte aus und kann so einen abgebrochenen Installationsvorgang fortsetzen. ==Konfiguration erneut durchführen== {{{#!vorlage befehl sudo dpkg-reconfigure locales }}} Führt die [:debconf:] Konfigurationsskripte des Pakets '''locales''' erneut aus (und generiert damit die Sprachpakete neu). ==Umleitung einrichten== {{{#!vorlage Befehl sudo dpkg-divert --local --rename /usr/bin/apt-build }}} Die Datei '''/usr/bin/apt-build''' wird für alle Pakete ohne Ausnahme auf die Datei '''/usr/bin/apt-build.distrib''' umgeleitet. Beim Erstellen der Umleitung wird die Datei direkt umbenannt. ==Umleitung entfernen== {{{#!vorlage Befehl sudo dpkg-divert --rename --remove /usr/bin/apt-build }}} Die im vorherigen Beispiel angelegte Umleitung wird wieder entfernt. Das `--rename` stellt sicher, dass die Datei wieder zurückumbenannt wird. Vergisst man dies, kann man die Datei einfach manuell z.B. mit [:mv:] umbenennen. =Links= ==Intern== * [:Paketverwaltung/Problembehebung:] - Sammlung häufiger Probleme und ihrer Lösung * [:debconf:] - * [:dpkg-www:] - Das lokale Softwareverzeichnis per Webbrowser durchsuchen * [:APT:] {Übersicht} * [:APT/apt-get:apt-get] - Frontend zur Bedienung der Paketverwaltung * [:aptitude:] - Frontend zur Bedienung der Paketverwaltung ==Extern== * [http://debiananwenderhandbuch.de/dpkg.html dpkg] {de} im Debian-Anwenderbuch * [http://linux.die.net/man/1/dpkg Manpage] {en} bei linux.die.net * [http://linux.die.net/man/1/dpkg-deb dpkg-deb] {en} bei linux.die.net * [http://linux.die.net/man/1/dpkg-query dpkg-query] {en} bei linux.die.net #tag: System, Shell, Installation, Server, Paketverwaltung