Zum Inhalt springen

Update-alternatives: Unterschied zwischen den Versionen

Aus Foxwiki
 
(28 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
{{DISPLAYTITLE:update-alternatives}}
'''update-alternatives''' - Verwaltung symbolischer Links zur Bestimmung von Standardwerten für Befehle
'''update-alternatives''' - Verwaltung symbolischer Links zur Bestimmung von Standardwerten für Befehle


== Beschreibung ==
== Beschreibung ==
update-alternatives erzeugt, entfernt, verwaltet und zeigt die Informationen über die symbolischen Links, die das [[Debian Alternativ-System]] bilden, an
; Programme mit ähnlicher Funktionalität
Es ist möglich, mehrere Programme, die die gleiche oder ähnliche Funktionalität bereitstellen, gleichzeitig auf einem System zu installieren
* Beispielsweise sind auf vielen Systemen mehrere Texteditoren gleichzeitig installiert
* Dies gibt den Benutzern eines Systems die Möglichkeit, falls gewünscht, jeweils einen anderen Editor zu verwenden, allerdings wird es damit für ein Programm schwierig, eine gute Wahl für einen Editor zum Starten zu treffen, falls der Benutzer keine spezielle Wahl getroffen hat
; Debians Alternativ-System
Debians Alternativ-System hat das Ziel, dieses Problem zu lösen
* Ein generischer Name im Dateisystem wird von allen Dateien, die austauschbare Funktionalität bereitstellen, verwendet
* Das Alternativ-System bestimmt zusammen mit dem Systemadministrator, welche Datei tatsächlich durch diesen generischen Namen referenziert wird
* Falls beispielsweise sowohl der Texteditor ed(1) als auch nvi(1) im System installiert sind, wird das Alternativ-System dafür sorgen, dass der generische Name /usr/bin/editor standardmäßig auf /usr/bin/nvi zeigt
* Der Systemadministrator kann dies ändern und dafür sorgen, dass er stattdessen auf /usr/bin/ed zeigt, und das Alternativ-System wird diese Einstellung nicht verändern, bis es explizit dazu aufgefordert wird
; Generische Name
Der generische Name ist kein direkter symbolischer Link auf die ausgewählte Alternative
* Stattdessen ist es ein symbolischer Link auf einen Namen im Alternativ-Verzeichnis, welches wiederum ein symbolischer Link auf die tatsächlich referenzierte Datei ist
* Dies ist so realisiert, damit die Änderungen des Systemadministrators auf das /etc-Verzeichnis beschränkt bleiben: der FHS (siehe dort) erklärt, warum dies eine gute Idee ist
; Update
Wenn ein Paket, das eine Datei mit einer bestimmten Funktionalität bereitstellt, installiert, geändert oder entfernt wird, wird update-alternatives aufgerufen, um die Informationen über diese Datei im Alternatives-System zu aktualisieren
* update-alternatives wird normalerweise in den folgenden Debian-Paketbetreuerskripten aufgerufen: postinst (configure), um die Alternative zu installieren und von prerm und postrm (remove), um die Alternative zu entfernen
* Hinweis: In den meisten (wenn nicht allen) Fällen sollte keine weitere Betreuerskriptaktion update-alternatives aufrufen, insbesondere weder upgrade noch disappear, da jede dieser anderen Aktionen zum Verlust des manuellen Zustands einer Alternative, oder zum Hin-und Herspringen oder zum kompletten Umspringen, wenn mehrere von ihnen die gleiche Priorität haben, führen kann
Es ist oft sinnvoll, dass eine Reihe von Alternativen synchronisiert werden, sodass sie als Gruppe geändert werden; wenn beispielsweise mehrere Versionen des vi(1) Editors installiert sind, sollte die Handbuchseite, die durch /usr/share/man/man1/vi.1 referenziert wird, zu dem ausführbaren Programm, dass durch /usr/bin/vi referenziert wird, gehören
* update-alternatives erledigt dies mithilfe von Master- und Slave-Links; wird der Master-Link geändert, wird auch jeder zugehörige Slave-Link geändert
* Ein Master-Link und seine zugehörigen Slave-Links bilden zusammen eine Link-Gruppe
; Linkgruppe
Eine Linkgruppe ist zu jeder Zeit in einem der beiden Modi: automatisch oder manuell
* Ist eine Gruppe im automatischen Modus, dann wird das Alternativ-System bei der Paketinstallation und -entfernung automatisch entscheiden, ob und wie die Links aktualisiert werden
* Im manuellen Modus wird das Alternativ-System die Wahl des Administrators beibehalten und Änderungen der Links vermeiden (außer etwas ist defekt)
Beim erstmaligen Einführen in das System befindet sich eine Linkgruppe im automatischen Modus
* Führt der Systemadministrator Änderungen an den automatischen Einstellungen des Systems durch, wird dies beim nächsten Aufruf von update-alternatives auf die Linkgruppe bemerkt und die Gruppe wird automatisch in den manuellen Modus umgeschaltet
Jede Alternative hat eine ihr zugeordnete Priorität
* Befindet sich eine Linkgruppe im automatischen Modus, zeigen die Mitglieder einer Gruppe auf die Alternative mit der höchsten Priorität
Wird die Option --config verwendet, dann zeigt update-alternatives alle Auswahlmöglichkeiten für die Link-Gruppe an, für die der gegebene Name der Master-Alternative-Name ist
* Die aktuelle Auswahl ist mit ‚*’ markiert
* Sie werden dann aufgefordert, Ihre Auswahl bezüglich der Linkgruppe anzugeben
* Abhängig von der getroffenen Auswahl könnte sich die Link-Gruppe nicht mehr im automatischen Modus befinden
* Sie müssen dann die Option
--auto verwenden, um wieder in den automatischen Zustand zurückzukehren (oder Sie können --config erneut ausführen und den als automatisch markierten Eintrag auswählen)
Falls Sie nicht-interaktiv konfigurieren möchten, können Sie stattdessen die Option --set verwenden (siehe unten)
Verschiedene Pakete, die die gleiche Datei bereitstellen, müssen dies kooperativ durchführen
* Anders gesagt ist in diesem Fall die Verwendung von update-alternatives für alle beteiligten Pakete zwingend
* Es ist nicht möglich, sich über eine Datei in einem Paket hinwegzusetzen, welches den update-alternatives-Mechanismus nicht verwendet
=== Begriffe ===
Da die Tätigkeiten von update-alternatives recht komplex sind, sollen einige spezielle Begriffe helfen, seine Vorgehensweise zu erläutern
{| class="wikitable options big"
|-
! Begiff !! Beschreibung
|-
| Generischer Name</br>Alternativ-Link || Ein Name wie /usr/bin/editor, der sich über das Alternativ-System auf eine Reihe von Dateien mit ähnlicher Funktionalität bezieht
|-
| Alternativ-Name || Der Name eines symbolischen Links im Alternativ-Verzeichnis
|-
| Alternative</br>Alternativ-Pfad || Der Name einer speziellen Datei im Dateisystem, die mittels eines generischen Namens über das Alternativ-System zugreifbar gemacht werden kann
|-
| Alternativ-Verzeichnis || Ein Verzeichnis, standardmäßig /etc/alternatives, das die Symlinks enthält
|-
| Administratives Verzeichnis || Ein Verzeichnis, standardmäßig /var/lib/dpkg/alternatives, das die update-alternatives Zustandsinformationen enthält
|-
| Linkgruppe || Ein Satz zusammengehörender Symlinks, die als Gruppe aktualisiert werden sollen
|-
| Master-Link || Der Alternativ-Link in einer Linkgruppe, der bestimmt, wie die anderen Links in der Gruppe konfiguriert werden
|-
| Slave-Link || Ein Alternativ-Link in einer Linkgruppe, der durch die Einstellung des Master-Links gesteuert wird
|-
| Automatischer Modus || Ist eine Linkgruppe im automatischen Modus, dann sorgt das Alternativ-System dafür, dass die Links in der Gruppe auf die für die Gruppe passende Alternative mit der höchsten Priorität zeigen
|-
| Manueller Modus || Ist eine Linkgruppe im manuellen Modus, dann führt das Alternativ-System keine Änderungen an den Einstellungen des Systemadministrators durch
|}
== Installation ==
== Installation ==
== Anwendungen ==
<syntaxhighlight lang="bash" highlight="1" line copy>
=== get-selections ===
</syntaxhighlight>
  sudo update-alternatives --get-selections
 
== Aufruf ==
<syntaxhighlight lang="bash" highlight="1" line>
update-alternatives [Option …] Befehl
</syntaxhighlight>
 
=== Optionen ===
{| class="wikitable sortable options gnu big"
|-
! Unix !! GNU !! Parameter !! Beschreibung
|-
| || || ||
|-
|}
 
=== Befehle ===
; --install Link Name Pfad Priorität [--slave Link Name Pfad] …
Fügt eine Gruppe von Alternativen zum System hinzu
* Link ist der generische Name des Master-Links, Name ist der Name seines Symlinks im Alternativ-Verzeichnis und Pfad ist die Alternative, die für den Master-Link eingeführt wird
* Die Argumente nach --slave sind der generische Name, Symlink-Name in dem Alternativ-Verzeichnis und der Alternativ-Pfad für den Slave-Link
* Null oder mehrere --slave-Optionen, jede von drei Argumenten gefolgt, können spezifiziert werden
* Beachten Sie, dass die Master-Alternative existieren muss, ansonsten schlägt der Aufruf fehl
* Falls allerdings eine Slave-Alternative nicht existiert, wird der zugehörige Slave-Alternative-Link einfach nicht installiert (es wird noch eine Warnung ausgegeben)
* Falls eine echte Datei an einer Stelle installiert wird, an der ein Alternativ-Link installiert werden muss, wird diese beibehalten, solange --force nicht verwandt wird
 
Falls der angegebene Alternativ-Name bereits in den Aufzeichnungen des Alternativ-Systems existiert, werden die angegebenen Informationen als neuer Satz von Alternativen für die Gruppe hinzugefügt
* Andernfalls wird eine neue Gruppe, eingestellt im automatischen Modus, mit dieser Information hinzugefügt
* Falls die Gruppe sich im automatischen Modus befindet und die Priorität der neu hinzugefügten Alternative höher ist als die jeder anderen installierten Alternative für diese Gruppe, werden die Symlinks aktualisiert, so dass sie auf die neu hinzugefügte Alternative zeigen
 
; --set Name Pfad
Setzt das Programm Pfad als Alternative für Name
* Dies ist äquivalent zu --config, ist aber nicht interaktiv und kann somit geskriptet werden
 
; --remove Name Pfad
Entfernt eine Alternative und alle zugehörigen Slave-Links
* Name ist ein Name im Alternativ-Verzeichnis, und Pfad ist ein absoluter Dateiname, zu dem Name gelinkt werden könnte
* Falls Name tatsächlich nach Pfad gelinkt ist, dann wird Name aktualisiert, um auf eine andere geeignete Alternative zu zeigen (und die Gruppe wird wieder in den automatischen Modus versetzt) oder entfernt, falls keine solche Alternative übrig bleibt
* Zugehörige Slave-Links werden entsprechend aktualisiert oder entfernt
* Falls der Link derzeit nicht auf Pfad zeigt, werden keine Links geändert; nur die Information über die Alternative wird entfernt
 
; --remove-all Name
Entfernt alle Alternativen und deren zugehörige Slave-Links
* Name ist ein Name im Alternativ-Verzeichnis
 
; --all
Ruft --config für alle Alternativen auf
* In der Kombination mit --skip-auto kann dies nützlich sein, um alle Alternativen zu prüfen und zu konfigurieren, die sich nicht im automatischen Modus befinden
* Defekte Alternativen werden auch angezeigt
* Ein Aufruf von yes '' | update-alternatives --force --all ist daher eine einfache Art, um alle defekten Alternativen zu reparieren
 
; --auto Name
Überführt die Linkgruppe hinter der Alternative mit Name Name in den automatischen Modus
* Bei diesem Prozess werden der Master-Symlink und seine Slave-Links aktualisiert, um auf die installierte Alternative mit höchster Priorität zu zeigen
 
; --display Name
Zeigt Informationen über die Linkgruppe an
* Die angezeigten Informationen enthalten den Modus der Gruppe (automatisch oder manuell), die Master- und Slave-Links, auf welche Alternative der Master-Link derzeit zeigt, welche weiteren Alternativen zur Verfügung stehen (und ihre zugehörigen Slave-Alternativen), und die installierte Alternative mit der höchsten Priorität
 
; --get-selections
Führt alle Master-Alternativ-Namen (die eine Linkgruppe steuern) mit ihrem Status auf (seit Version 1.15.0)
* Jede Zeile enthält bis zu 3 Felder (getrennt durch mindestens ein Leerzeichen)
* Im ersten Feld steht der Alternativ-Name, im zweiten der Status (entweder auto oder manual) und im letzten die derzeitige Wahl der Alternative (Achtung: Dies ist ein Dateiname, der Leerzeichen enthalten kann)
 
; --set-selections
Liest eine Konfiguration von Alternativen über die Standardeingabe im von „--get-selections“ generierten Format und konfiguriert die Alternativen entsprechend neu (seit Version 1.15.0)
 
; --query Name
Zeigt alle Informationen über die Linkgruppe an, wie dies auch von --display erfolgt, allerdings in einem maschinenlesbaren Format (seit Version 1.15.0, siehe nachfolgenden Abschnitt "ABFRAGE-FORMAT")
 
; --list Name
Zeigt alle Ziele der Linkgruppe an
 
; --config Name
Zeigt die verfügbaren Alternativen für eine Linkgruppe an und erlaubt es dem Benutzer, interaktiv auszuwählen, welche zu benutzen ist
* Die Linkgruppe wird aktualisiert
 
; --help
Zeigt einen Hinweis zum Aufruf und beendet das Programm
 
; --version
Gibt die Version aus und beendet das Programm
 
=== Parameter ===
 
=== Umgebung ===
{| class="wikitable options big"
|-
! Variable !! Beschreibung
|-
| DPKG_ROOT || Falls gesetzt und die Option --instdir oder --root nicht angegeben wurde, wird dies als Dateisystemwurzelverzeichnis verwandt
|-
| DPKG_ADMINDIR || Falls gesetzt und die Option --admindir nicht angegeben wurde, wird dies als Basis-Administrationsverzeichnis verwandt
|}
 
=== Exit-Status ===
{| class="wikitable options col1center big"
|-
! Wert !! Beschreibung
|-
| 0 || Erfolg
|-
| >0  || Fehler
|}
 
== Anwendung ==
=== Einstellungen anzeigen ===
; get-selections
<syntaxhighlight lang="bash" highlight="1" line copy>
sudo update-alternatives --get-selections
</syntaxhighlight>
 
<syntaxhighlight lang="bash" highlight="" line>
  animate                        auto    /usr/bin/animate-im6.q16
  animate                        auto    /usr/bin/animate-im6.q16
  animate-im6                    auto    /usr/bin/animate-im6.q16
  animate-im6                    auto    /usr/bin/animate-im6.q16
Zeile 19: Zeile 209:
  cc                            auto    /usr/bin/gcc
  cc                            auto    /usr/bin/gcc
  [...]
  [...]
</syntaxhighlight>
=== Einstellungen setzen ===
; config
<syntaxhighlight lang="bash" highlight="1" line copy>
sudo update-alternatives --config vi
</syntaxhighlight>
<syntaxhighlight lang="bash" highlight="" line>
There are 2 choices for the alternative vi (providing /usr/bin/vi)


=== config ===
sudo '''update-alternatives --config vi'''
There are 2 choices for the alternative vi (providing /usr/bin/vi).
   Selection    Path                Priority  Status
   Selection    Path                Priority  Status
  ------------------------------------------------------------
  ------------------------------------------------------------
Zeile 29: Zeile 224:
   1            /usr/bin/vim.basic  30        manual mode
   1            /usr/bin/vim.basic  30        manual mode
   2            /usr/bin/vim.tiny    15        manual mode
   2            /usr/bin/vim.tiny    15        manual mode
Press <enter> to keep the current choice[*], or type selection number:


Press <enter> to keep the current choice[*], or type selection number
</syntaxhighlight>
<syntaxhighlight lang="bash" highlight="1" line copy>
sudo update-alternatives --config editor
</syntaxhighlight>
<syntaxhighlight lang="bash" highlight="" line>
[sudo] password for dirkwagner
There are 3 choices for the alternative editor (providing /usr/bin/editor)


sudo update-alternatives --config editor
[sudo] password for dirkwagner:
There are 3 choices for the alternative editor (providing /usr/bin/editor).
  Selection    Path                Priority  Status
  Selection    Path                Priority  Status
  ------------------------------------------------------------
  ------------------------------------------------------------
0            /bin/nano            40        auto mode
  0            /bin/nano            40        auto mode
1            /bin/nano            40        manual mode
  1            /bin/nano            40        manual mode
  * 2         /usr/bin/vim.basic  30        manual mode
  * 2           /usr/bin/vim.basic  30        manual mode
3            /usr/bin/vim.tiny    15        manual mode
  3            /usr/bin/vim.tiny    15        manual mode
 
  Press <enter> to keep the current choice[*], or type selection number:
  Press <enter> to keep the current choice[*], or type selection number
</syntaxhighlight>
 
=== Beispiele ===
Es gibt mehrere Pakete, die einen vi-kompatiblen Texteditor bereitstellen, beispielsweise nvi und vim. Welcher benutzt wird, wird durch die Linkgruppe vi eingestellt, welche Links für das Programm selbst und die zugehörige Handbuchseite beinhaltet
 
Um alle verfügbaren Programme anzuzeigen, die vi bereitstellen, und die dazu gehörigen Einstellungen, benutzen Sie die Aktion --display
<syntaxhighlight lang="bash" highlight="1" line copy>
update-alternatives --display vi
</syntaxhighlight>
 
Um eine bestimmte vi-Implementation auszuwählen, benutzen Sie als Root den folgenden Befehl und wählen dann eine Zahl aus der Liste aus
<syntaxhighlight lang="bash" highlight="1" line copy>
update-alternatives --config vi
</syntaxhighlight>
 
Um zur automatischen Auswahl der vi-Implementation zurückzukehren, führen Sie Folgendes als Root aus
<syntaxhighlight lang="bash" highlight="1" line copy>
update-alternatives --auto vi
</syntaxhighlight>
 
=== Beispiel ===
<syntaxhighlight lang="bash" highlight="1" line copy>
update-alternatives --query editor
</syntaxhighlight>
<syntaxhighlight lang="bash" highlight="" line>
Name: editor Link: /usr/bin/editor Slaves
editor.1.gz /usr/share/man/man1/editor.1.gz editor.fr.1.gz /usr/share/man/fr/man1/editor.1.gz editor.it.1.gz /usr/share/man/it/man1/editor.1.gz editor.pl.1.gz /usr/share/man/pl/man1/editor.1.gz editor.ru.1.gz /usr/share/man/ru/man1/editor.1.gz Status: auto Best: /usr/bin/vim.basic Value: /usr/bin/vim.basic
 
Alternative: /bin/ed Priority: -100
Slaves
editor.1.gz /usr/share/man/man1/ed.1.gz


== Aufruf ==
Alternative: /usr/bin/vim.basic Priority: 50
$ update-alternatives [Option …] Befehl
Slaves
editor.1.gz /usr/share/man/man1/vim.1.gz editor.fr.1.gz /usr/share/man/fr/man1/vim.1.gz editor.it.1.gz /usr/share/man/it/man1/vim.1.gz editor.pl.1.gz /usr/share/man/pl/man1/vim.1.gz editor.ru.1.gz /usr/share/man/ru/man1/vim.1.gz
</syntaxhighlight>


=== Optionen ===
=== Problembehebung ===
=== Argumente ===
Mit --verbose berichtet update-alternatives fortwährend über seine Aktivitäten auf seinem Standardausgabekanal. Falls Probleme auftreten, gibt update-alternatives eine Fehlermeldung auf seinem Standardfehlerkanal aus und beendet sich mit dem Exit-Status 2. Die Diagnostiken sollten selbsterklärend sein; falls Sie dies nicht so empfinden, melden Sie dies bitte als Fehler
=== Umgebungsvariablen ===
=== Exit-Status ===


== Konfiguration ==
== Konfiguration ==
=== Dateien ===
=== Dateien ===
== Sicherheit ==
{| class="wikitable options big"
== Dokumentation ==
|-
=== RFC ===
! Datei !! Beschreibung
=== Man-Page ===
|-
# update-alternatives(1)
| ||
# dpkg suite
|-
# update-alternatives(1) 1.21.9 2022-10-15
| ||
|}


=== Info-Pages ===
<noinclude>
== Siehe auch ==
# ln(1)
# FHS (der Dateisystem-Hierarchie-Standard, Filesystem Hierarchy Standard)


== Links ==
== Anhang ==
=== Projekt-Homepage ===
=== Siehe auch ===
=== Weblinks ===
<div style="column-count:2">
<categorytree hideroot=on mode="pages">{{BASEPAGENAME}}</categorytree>
</div>
----
{{Special:PrefixIndex/{{BASEPAGENAME}}/}}
----
* [[dpkg]] suite
* [[ln]](1)
* [[FHS]] (der Dateisystem-Hierarchie-Standard, Filesystem Hierarchy Standard)


=== Dokumentation ===
; Man-Page
# [https://manpages.debian.org/stable/dpkg/update-alternatives.1.de.html update-alternatives(1)]
<!--
; Info-Pages
-->
=== Links ===
==== Projekt ====
==== Weblinks ====


{{DEFAULTSORT:update-alternatives}}
{{DEFAULTSORT:update-alternatives}}
{{DISPLAYTITLE:update-alternatives}}


[[Kategorie:APT]]
[[Kategorie:Linux/Software/Verwaltung]]
[[Kategorie:Linux/Software/Verwaltung]]
[[Kategorie:Linux/Befehl]]
</noinclude>

Aktuelle Version vom 8. März 2026, 09:50 Uhr

update-alternatives - Verwaltung symbolischer Links zur Bestimmung von Standardwerten für Befehle

Beschreibung

update-alternatives erzeugt, entfernt, verwaltet und zeigt die Informationen über die symbolischen Links, die das Debian Alternativ-System bilden, an

Programme mit ähnlicher Funktionalität

Es ist möglich, mehrere Programme, die die gleiche oder ähnliche Funktionalität bereitstellen, gleichzeitig auf einem System zu installieren

  • Beispielsweise sind auf vielen Systemen mehrere Texteditoren gleichzeitig installiert
  • Dies gibt den Benutzern eines Systems die Möglichkeit, falls gewünscht, jeweils einen anderen Editor zu verwenden, allerdings wird es damit für ein Programm schwierig, eine gute Wahl für einen Editor zum Starten zu treffen, falls der Benutzer keine spezielle Wahl getroffen hat
Debians Alternativ-System

Debians Alternativ-System hat das Ziel, dieses Problem zu lösen

  • Ein generischer Name im Dateisystem wird von allen Dateien, die austauschbare Funktionalität bereitstellen, verwendet
  • Das Alternativ-System bestimmt zusammen mit dem Systemadministrator, welche Datei tatsächlich durch diesen generischen Namen referenziert wird
  • Falls beispielsweise sowohl der Texteditor ed(1) als auch nvi(1) im System installiert sind, wird das Alternativ-System dafür sorgen, dass der generische Name /usr/bin/editor standardmäßig auf /usr/bin/nvi zeigt
  • Der Systemadministrator kann dies ändern und dafür sorgen, dass er stattdessen auf /usr/bin/ed zeigt, und das Alternativ-System wird diese Einstellung nicht verändern, bis es explizit dazu aufgefordert wird
Generische Name

Der generische Name ist kein direkter symbolischer Link auf die ausgewählte Alternative

  • Stattdessen ist es ein symbolischer Link auf einen Namen im Alternativ-Verzeichnis, welches wiederum ein symbolischer Link auf die tatsächlich referenzierte Datei ist
  • Dies ist so realisiert, damit die Änderungen des Systemadministrators auf das /etc-Verzeichnis beschränkt bleiben: der FHS (siehe dort) erklärt, warum dies eine gute Idee ist
Update

Wenn ein Paket, das eine Datei mit einer bestimmten Funktionalität bereitstellt, installiert, geändert oder entfernt wird, wird update-alternatives aufgerufen, um die Informationen über diese Datei im Alternatives-System zu aktualisieren

  • update-alternatives wird normalerweise in den folgenden Debian-Paketbetreuerskripten aufgerufen: postinst (configure), um die Alternative zu installieren und von prerm und postrm (remove), um die Alternative zu entfernen
  • Hinweis: In den meisten (wenn nicht allen) Fällen sollte keine weitere Betreuerskriptaktion update-alternatives aufrufen, insbesondere weder upgrade noch disappear, da jede dieser anderen Aktionen zum Verlust des manuellen Zustands einer Alternative, oder zum Hin-und Herspringen oder zum kompletten Umspringen, wenn mehrere von ihnen die gleiche Priorität haben, führen kann

Es ist oft sinnvoll, dass eine Reihe von Alternativen synchronisiert werden, sodass sie als Gruppe geändert werden; wenn beispielsweise mehrere Versionen des vi(1) Editors installiert sind, sollte die Handbuchseite, die durch /usr/share/man/man1/vi.1 referenziert wird, zu dem ausführbaren Programm, dass durch /usr/bin/vi referenziert wird, gehören

  • update-alternatives erledigt dies mithilfe von Master- und Slave-Links; wird der Master-Link geändert, wird auch jeder zugehörige Slave-Link geändert
  • Ein Master-Link und seine zugehörigen Slave-Links bilden zusammen eine Link-Gruppe
Linkgruppe

Eine Linkgruppe ist zu jeder Zeit in einem der beiden Modi: automatisch oder manuell

  • Ist eine Gruppe im automatischen Modus, dann wird das Alternativ-System bei der Paketinstallation und -entfernung automatisch entscheiden, ob und wie die Links aktualisiert werden
  • Im manuellen Modus wird das Alternativ-System die Wahl des Administrators beibehalten und Änderungen der Links vermeiden (außer etwas ist defekt)

Beim erstmaligen Einführen in das System befindet sich eine Linkgruppe im automatischen Modus

  • Führt der Systemadministrator Änderungen an den automatischen Einstellungen des Systems durch, wird dies beim nächsten Aufruf von update-alternatives auf die Linkgruppe bemerkt und die Gruppe wird automatisch in den manuellen Modus umgeschaltet

Jede Alternative hat eine ihr zugeordnete Priorität

  • Befindet sich eine Linkgruppe im automatischen Modus, zeigen die Mitglieder einer Gruppe auf die Alternative mit der höchsten Priorität

Wird die Option --config verwendet, dann zeigt update-alternatives alle Auswahlmöglichkeiten für die Link-Gruppe an, für die der gegebene Name der Master-Alternative-Name ist

  • Die aktuelle Auswahl ist mit ‚*’ markiert
  • Sie werden dann aufgefordert, Ihre Auswahl bezüglich der Linkgruppe anzugeben
  • Abhängig von der getroffenen Auswahl könnte sich die Link-Gruppe nicht mehr im automatischen Modus befinden
  • Sie müssen dann die Option

--auto verwenden, um wieder in den automatischen Zustand zurückzukehren (oder Sie können --config erneut ausführen und den als automatisch markierten Eintrag auswählen)

Falls Sie nicht-interaktiv konfigurieren möchten, können Sie stattdessen die Option --set verwenden (siehe unten)

Verschiedene Pakete, die die gleiche Datei bereitstellen, müssen dies kooperativ durchführen

  • Anders gesagt ist in diesem Fall die Verwendung von update-alternatives für alle beteiligten Pakete zwingend
  • Es ist nicht möglich, sich über eine Datei in einem Paket hinwegzusetzen, welches den update-alternatives-Mechanismus nicht verwendet

Begriffe

Da die Tätigkeiten von update-alternatives recht komplex sind, sollen einige spezielle Begriffe helfen, seine Vorgehensweise zu erläutern

Begiff Beschreibung
Generischer Name
Alternativ-Link
Ein Name wie /usr/bin/editor, der sich über das Alternativ-System auf eine Reihe von Dateien mit ähnlicher Funktionalität bezieht
Alternativ-Name Der Name eines symbolischen Links im Alternativ-Verzeichnis
Alternative
Alternativ-Pfad
Der Name einer speziellen Datei im Dateisystem, die mittels eines generischen Namens über das Alternativ-System zugreifbar gemacht werden kann
Alternativ-Verzeichnis Ein Verzeichnis, standardmäßig /etc/alternatives, das die Symlinks enthält
Administratives Verzeichnis Ein Verzeichnis, standardmäßig /var/lib/dpkg/alternatives, das die update-alternatives Zustandsinformationen enthält
Linkgruppe Ein Satz zusammengehörender Symlinks, die als Gruppe aktualisiert werden sollen
Master-Link Der Alternativ-Link in einer Linkgruppe, der bestimmt, wie die anderen Links in der Gruppe konfiguriert werden
Slave-Link Ein Alternativ-Link in einer Linkgruppe, der durch die Einstellung des Master-Links gesteuert wird
Automatischer Modus Ist eine Linkgruppe im automatischen Modus, dann sorgt das Alternativ-System dafür, dass die Links in der Gruppe auf die für die Gruppe passende Alternative mit der höchsten Priorität zeigen
Manueller Modus Ist eine Linkgruppe im manuellen Modus, dann führt das Alternativ-System keine Änderungen an den Einstellungen des Systemadministrators durch

Installation

Aufruf

update-alternatives [Option ] Befehl

Optionen

Unix GNU Parameter Beschreibung

Befehle

--install Link Name Pfad Priorität [--slave Link Name Pfad] …

Fügt eine Gruppe von Alternativen zum System hinzu

  • Link ist der generische Name des Master-Links, Name ist der Name seines Symlinks im Alternativ-Verzeichnis und Pfad ist die Alternative, die für den Master-Link eingeführt wird
  • Die Argumente nach --slave sind der generische Name, Symlink-Name in dem Alternativ-Verzeichnis und der Alternativ-Pfad für den Slave-Link
  • Null oder mehrere --slave-Optionen, jede von drei Argumenten gefolgt, können spezifiziert werden
  • Beachten Sie, dass die Master-Alternative existieren muss, ansonsten schlägt der Aufruf fehl
  • Falls allerdings eine Slave-Alternative nicht existiert, wird der zugehörige Slave-Alternative-Link einfach nicht installiert (es wird noch eine Warnung ausgegeben)
  • Falls eine echte Datei an einer Stelle installiert wird, an der ein Alternativ-Link installiert werden muss, wird diese beibehalten, solange --force nicht verwandt wird

Falls der angegebene Alternativ-Name bereits in den Aufzeichnungen des Alternativ-Systems existiert, werden die angegebenen Informationen als neuer Satz von Alternativen für die Gruppe hinzugefügt

  • Andernfalls wird eine neue Gruppe, eingestellt im automatischen Modus, mit dieser Information hinzugefügt
  • Falls die Gruppe sich im automatischen Modus befindet und die Priorität der neu hinzugefügten Alternative höher ist als die jeder anderen installierten Alternative für diese Gruppe, werden die Symlinks aktualisiert, so dass sie auf die neu hinzugefügte Alternative zeigen
--set Name Pfad

Setzt das Programm Pfad als Alternative für Name

  • Dies ist äquivalent zu --config, ist aber nicht interaktiv und kann somit geskriptet werden
--remove Name Pfad

Entfernt eine Alternative und alle zugehörigen Slave-Links

  • Name ist ein Name im Alternativ-Verzeichnis, und Pfad ist ein absoluter Dateiname, zu dem Name gelinkt werden könnte
  • Falls Name tatsächlich nach Pfad gelinkt ist, dann wird Name aktualisiert, um auf eine andere geeignete Alternative zu zeigen (und die Gruppe wird wieder in den automatischen Modus versetzt) oder entfernt, falls keine solche Alternative übrig bleibt
  • Zugehörige Slave-Links werden entsprechend aktualisiert oder entfernt
  • Falls der Link derzeit nicht auf Pfad zeigt, werden keine Links geändert; nur die Information über die Alternative wird entfernt
--remove-all Name

Entfernt alle Alternativen und deren zugehörige Slave-Links

  • Name ist ein Name im Alternativ-Verzeichnis
--all

Ruft --config für alle Alternativen auf

  • In der Kombination mit --skip-auto kann dies nützlich sein, um alle Alternativen zu prüfen und zu konfigurieren, die sich nicht im automatischen Modus befinden
  • Defekte Alternativen werden auch angezeigt
  • Ein Aufruf von yes | update-alternatives --force --all ist daher eine einfache Art, um alle defekten Alternativen zu reparieren
--auto Name

Überführt die Linkgruppe hinter der Alternative mit Name Name in den automatischen Modus

  • Bei diesem Prozess werden der Master-Symlink und seine Slave-Links aktualisiert, um auf die installierte Alternative mit höchster Priorität zu zeigen
--display Name

Zeigt Informationen über die Linkgruppe an

  • Die angezeigten Informationen enthalten den Modus der Gruppe (automatisch oder manuell), die Master- und Slave-Links, auf welche Alternative der Master-Link derzeit zeigt, welche weiteren Alternativen zur Verfügung stehen (und ihre zugehörigen Slave-Alternativen), und die installierte Alternative mit der höchsten Priorität
--get-selections

Führt alle Master-Alternativ-Namen (die eine Linkgruppe steuern) mit ihrem Status auf (seit Version 1.15.0)

  • Jede Zeile enthält bis zu 3 Felder (getrennt durch mindestens ein Leerzeichen)
  • Im ersten Feld steht der Alternativ-Name, im zweiten der Status (entweder auto oder manual) und im letzten die derzeitige Wahl der Alternative (Achtung: Dies ist ein Dateiname, der Leerzeichen enthalten kann)
--set-selections

Liest eine Konfiguration von Alternativen über die Standardeingabe im von „--get-selections“ generierten Format und konfiguriert die Alternativen entsprechend neu (seit Version 1.15.0)

--query Name

Zeigt alle Informationen über die Linkgruppe an, wie dies auch von --display erfolgt, allerdings in einem maschinenlesbaren Format (seit Version 1.15.0, siehe nachfolgenden Abschnitt "ABFRAGE-FORMAT")

--list Name

Zeigt alle Ziele der Linkgruppe an

--config Name

Zeigt die verfügbaren Alternativen für eine Linkgruppe an und erlaubt es dem Benutzer, interaktiv auszuwählen, welche zu benutzen ist

  • Die Linkgruppe wird aktualisiert
--help

Zeigt einen Hinweis zum Aufruf und beendet das Programm

--version

Gibt die Version aus und beendet das Programm

Parameter

Umgebung

Variable Beschreibung
DPKG_ROOT Falls gesetzt und die Option --instdir oder --root nicht angegeben wurde, wird dies als Dateisystemwurzelverzeichnis verwandt
DPKG_ADMINDIR Falls gesetzt und die Option --admindir nicht angegeben wurde, wird dies als Basis-Administrationsverzeichnis verwandt

Exit-Status

Wert Beschreibung
0 Erfolg
>0 Fehler

Anwendung

Einstellungen anzeigen

get-selections
sudo update-alternatives --get-selections
 animate                        auto     /usr/bin/animate-im6.q16
 animate-im6                    auto     /usr/bin/animate-im6.q16
 aptitude                       auto     /usr/bin/aptitude-curses
 arptables                      auto     /usr/sbin/arptables-nft
 automake                       auto     /usr/bin/automake-1.16
 awk                            auto     /usr/bin/gawk
 builtins.7.gz                  auto     /usr/share/man/man7/bash-builtins.7.gz
 c++                            auto     /usr/bin/g++
 c89                            auto     /usr/bin/c89-gcc
 c99                            auto     /usr/bin/c99-gcc
 cc                             auto     /usr/bin/gcc
 [...]

Einstellungen setzen

config
sudo update-alternatives --config vi
 There are 2 choices for the alternative vi (providing /usr/bin/vi)

   Selection    Path                Priority   Status
 ------------------------------------------------------------
 * 0            /usr/bin/vim.basic   30        auto mode
   1            /usr/bin/vim.basic   30        manual mode
   2            /usr/bin/vim.tiny    15        manual mode

 Press <enter> to keep the current choice[*], or type selection number
 sudo update-alternatives --config editor
 [sudo] password for dirkwagner
 There are 3 choices for the alternative editor (providing /usr/bin/editor)

 Selection    Path                Priority   Status
 ------------------------------------------------------------
   0            /bin/nano            40        auto mode
   1            /bin/nano            40        manual mode
 * 2            /usr/bin/vim.basic   30        manual mode
   3            /usr/bin/vim.tiny    15        manual mode

 Press <enter> to keep the current choice[*], or type selection number

Beispiele

Es gibt mehrere Pakete, die einen vi-kompatiblen Texteditor bereitstellen, beispielsweise nvi und vim. Welcher benutzt wird, wird durch die Linkgruppe vi eingestellt, welche Links für das Programm selbst und die zugehörige Handbuchseite beinhaltet

Um alle verfügbaren Programme anzuzeigen, die vi bereitstellen, und die dazu gehörigen Einstellungen, benutzen Sie die Aktion --display

update-alternatives --display vi

Um eine bestimmte vi-Implementation auszuwählen, benutzen Sie als Root den folgenden Befehl und wählen dann eine Zahl aus der Liste aus

update-alternatives --config vi

Um zur automatischen Auswahl der vi-Implementation zurückzukehren, führen Sie Folgendes als Root aus

update-alternatives --auto vi

Beispiel

update-alternatives --query editor
Name: editor Link: /usr/bin/editor Slaves
editor.1.gz /usr/share/man/man1/editor.1.gz editor.fr.1.gz /usr/share/man/fr/man1/editor.1.gz editor.it.1.gz /usr/share/man/it/man1/editor.1.gz editor.pl.1.gz /usr/share/man/pl/man1/editor.1.gz editor.ru.1.gz /usr/share/man/ru/man1/editor.1.gz Status: auto Best: /usr/bin/vim.basic Value: /usr/bin/vim.basic

Alternative: /bin/ed Priority: -100
Slaves
editor.1.gz /usr/share/man/man1/ed.1.gz

Alternative: /usr/bin/vim.basic Priority: 50
Slaves
editor.1.gz /usr/share/man/man1/vim.1.gz editor.fr.1.gz /usr/share/man/fr/man1/vim.1.gz editor.it.1.gz /usr/share/man/it/man1/vim.1.gz editor.pl.1.gz /usr/share/man/pl/man1/vim.1.gz editor.ru.1.gz /usr/share/man/ru/man1/vim.1.gz

Problembehebung

Mit --verbose berichtet update-alternatives fortwährend über seine Aktivitäten auf seinem Standardausgabekanal. Falls Probleme auftreten, gibt update-alternatives eine Fehlermeldung auf seinem Standardfehlerkanal aus und beendet sich mit dem Exit-Status 2. Die Diagnostiken sollten selbsterklärend sein; falls Sie dies nicht so empfinden, melden Sie dies bitte als Fehler

Konfiguration

Dateien

Datei Beschreibung


Anhang

Siehe auch



  • dpkg suite
  • ln(1)
  • FHS (der Dateisystem-Hierarchie-Standard, Filesystem Hierarchy Standard)

Dokumentation

Man-Page
  1. update-alternatives(1)

Projekt