Ich versuche, eine Staging-Umgebung in einer VM einzurichten, um Updates zu testen, bevor sie auf mein Hauptsystem angewendet werden.
Zu diesem Zweck habe ich eine Basisinstallation von Debian Wheezy (wie auf dem Hauptsystem) in der VM durchgeführt und bin dann als root von der VM aus gelaufen:
# dpkg --clear-selections
# dpkg --add-architecture i386
# apt-get update
# ssh me@main-system 'dpkg --get-selections | grep -v deinstall' | \
dpkg --set-selections
Die i386 Architektur wird in meinem Fall leider benötigt; das system ist amd64 native.
Das Problem liegt beim dpkg --set-selections
Ausführen in der VM. Ich habe einige Pakete, die eine spezielle Behandlung erfordern (das ist eigentlich der Hauptgrund, warum ich überhaupt eine Staging-Umgebung haben möchte), aber wenn ich den letzten obigen Befehl ausführe, erhalte ich ungefähr eine Unmenge von Ausgabezeilen wie:
dpkg: warning: package not in database at line NNN: package-name
für Pakete, die eigentlich im Basissystem vorhanden sein sollten. Beispiele sind xterm
, yelp
und zip
.
Nun zu meiner Frage:
Was ist der genaue Vorgang, um die Paketauswahlliste von einem Debian-System auf ein anderes zu übertragen (bei gleichem Debian-Release-Stand in Wheezy) und diese Änderungen anschließend anzuwenden? Das Ziel ist, dass beide die gleiche Liste der installierten Pakete haben, idealerweise so, dass das Ausführen eines diff
zwischen den Ausgaben von dpkg --get-selections
oder dpkg --list
auf den beiden zurückkommt und keine Unterschiede zeigt.
Der grep -v deinstall
Teil wurde von Prevent-Paketendpkg --set-selections
entlehnt , die nach dem Ausführen von Ask Ubuntu entfernt wurden.
Ich habe die Quelle in der VM so geändert, dass sie mit der auf dem Hauptsystem übereinstimmt, und Folgendes installiert apt-transport-https
:
deb https://ftp-stud.hs-esslingen.de/debian/ wheezy main non-free
deb-src https://ftp-stud.hs-esslingen.de/debian/ wheezy main non-free
deb https://ftp-stud.hs-esslingen.de/debian/ wheezy-updates main non-free
deb-src https://ftp-stud.hs-esslingen.de/debian/ wheezy-updates main non-free
deb [arch=amd64] http://archive.zfsonlinux.org/debian wheezy main
Wenn ich mir die Ausgabe von --set-selections ansehe, sehe ich:
dpkg: warning: package not in database at line 1: a2ps
dpkg: warning: package not in database at line 1: abiword
dpkg: warning: package not in database at line 1: abiword-common
dpkg: warning: package not in database at line 1: abiword-plugin-grammar
dpkg: warning: package not in database at line 1: abiword-plugin-mathview
dpkg: warning: package not in database at line 1: accountsservice
dpkg: warning: package not in database at line 1: acl
dpkg: warning: package not in database at line 4: aglfn
dpkg: warning: package not in database at line 4: aisleriot
dpkg: warning: package not in database at line 4: alacarte
dpkg: warning: package not in database at line 4: alien
...
Die Zeilennummern sahen ungerade aus und der entsprechende Teil der Ausgabe von --get-selections ist:
a2ps install
abiword install
abiword-common install
abiword-plugin-grammar install
abiword-plugin-mathview install
accountsservice install
acl install
acpi-support-base install
acpid install
adduser install
aglfn install
aisleriot install
alacarte install
alien install
Beachten Sie, dass in zwischen acl
und aglfn
sind acpi-support-base
, acpid
und adduser
für die keine Fehler gemeldet werden . Es scheint, dass die Pakete, für die Fehler gemeldet werden, entweder den un
Angaben entsprechen dpkg -l
oder dpkg -l
überhaupt keine Ahnung davon haben ( dpkg-query: no packages found matching ...
). Ich weiß, dass es einige lokal installierte Pakete gibt, aber nicht viele. i386
nicht Figur , bis gcc-4.7-base:i386 install
viel weiter unten in der Liste (Linie 342 in der --get-Auswahlausgabe).
quelle
dpkg --get-selections … | … dpkg --set-selections
ist der Weg, um die Paketauswahl zu replizieren. Wenn es für Sie fehlschlägt, müssen Sie weitere Informationen darüber bereitstellen, warum. Veröffentlichen Sie Ihren vollständigen Quellensatz auf beiden Systemen, die Ausgabe vondpkg --get-selections
und das vollständige Transkript vondpkg --get-selections
(vielleicht können wir ein Muster erkennen, indem wir sehen, was funktioniert und was nicht). Ist das Hauptsystem amd64 oder i386? Funktioniert es, wenn Sie die i386-Architektur nicht hinzufügen?dpkg --get-selections
(und ich nehme an, Sie meinten dasdpkg --set-selections
Transkript?)? Sogar nur der erstere hat mehr als 3.600 Zeilen und ungefähr 100 KB./var/lib/dpkg/Packages
(die noch länger ist) könnte ebenfalls nützlich sein - dies könnte ein Symptom für eine beschädigte Paketdatei sein.Antworten:
Verwenden Sie das
apt-clone
Dienstprogramm , um eine Debian-Installation zu klonen . Es ist in Debian seit wheezy und in Ubuntu seit 12.04 verfügbar (als separates Paket, nicht Teil der Standardinstallation). Führen Sie auf dem vorhandenen Computer ausDadurch wird eine Datei erstellt
foo.apt-clone.tar.gz
. Kopieren Sie es auf den Zielcomputer und führen Sie es ausWenn Sie mit einem alten System arbeiten, auf dem
apt-clone
es nicht verfügbar ist, oder wenn Sie nur die Liste der installierten Pakete, aber keine Konfigurationsdatei replizieren möchten, führen Sie die folgenden manuellen Schritte aus.Auf dem Quellcomputer:
Auf dem Zielcomputer:
Ich glaube, dass Sie von einer inkompatiblen Änderung in dpkg betroffen sind, die es zuerst zu Keuchen brachte. Siehe Fehler # 703092 für den Hintergrund.
Die Kurzgeschichte ist, dass
dpkg --set-selections
jetzt nur Paketnamen akzeptiert werden, die in der Datei/var/lib/dpkg/status
oder vorhanden sind/var/lib/dpkg/available
. Wenn Sie APT nur zum Verwalten von Paketen verwenden, wie die meisten Leute,/var/lib/dpkg/available
wird dies nicht auf dem neuesten Stand gehalten.Führen Sie nach dem Ausführen
apt-get update
und vor dem Ausführen vondpkg --set-selections
undapt-get -u dselect-upgrade
den folgenden Befehl aus:Ab Jessie können Sie dies vereinfachen
Alternativ können Sie auch ausführen
oder noch einfacher
Eine weitere einfache Methode, bei der kein zusätzliches Paket installiert werden muss, sondern die Paketlisten erneut heruntergeladen werden, ist
Weitere Informationen finden Sie in den häufig gestellten Fragen zu dpkg . (Dies wird in der Manpage von dpkg erwähnt, aber eher auf eine Weise, die Sie an das Problem erinnert, wenn Sie es bereits gewusst haben, und nicht auf eine Weise, die erklärt, wie Sie das Problem lösen können!)
Beachten Sie, dass das Klonen einer Paketinstallation mit
dpkg --set-selections
nicht die automatische / manuelle Markierung in APT wiederherstellt. Weitere Informationen finden Sie unter Wiederherstellen aller Daten und Abhängigkeiten aus dpkg --set-selections '*' . Mit können Sie die Markierungen im Quellsystem speichernund stellen Sie sie auf dem Zielsystem mit wieder her
quelle
dpkg --set-selections
seit dem Pre-Wheezy nichts mehr benutzt habe !--set-selections
. Wie wende ich die Änderungen an? Sogarapt-get -u dist-upgrade
erwähnt nur eine Handvoll Pakete (alle ZFS-bezogen), von denen Hunderte, wenn nicht Tausende betroffen sein sollten.apt-get -u dselect-upgrade
Wie ich es gemacht habe
Auf Quelle host:
Pflege,
/etc/apt/sources.list.d
wenn verwendet ...Kopieren Sie dann die
source.sel
Datei auf den Zielhost.Am Ziel - Host:
passe sources.list auch mit unterschiedlichen spiegeln an, aber gleiche komponentenliste .
Und jetzt installiert mein Zielhost gerade eine Menge Dinge. Dann könnte ich mir etwas Zeit nehmen, um dies zu veröffentlichen.
quelle