Product SiteDocumentation Site

5.4. Manipulera paket med dpkg

dpkg är baskommandot för att hantera Debian-paket i systemet. Om du har ett eller flera .deb paket så är det dpkg som möjliggör installation eller analysering av deras innehåll. Men detta program har enbart en begränsad uppfattning av Debians universium: den vet vad som är installerat på systemet samt vad den får tillsagt via kommandoraden, men vet ingenting om andra tillgängliga paket. På grund av detta kommer den misslyckas om ett beroende inte är uppfyllt. Verktyg så som apt och aptitude kommer och andra sidan skapa en lista av beroenden för att kunna installera allt så automatiserat som möjligt.

5.4.1. Installerar paket

dpkg är i första hand ett verktyg för att installera ett Debian-paket som redan finns tillgängligt (eftersom verktyget inte laddar ner någonting). För att genomföra en sådan operation använder vi flaggorna -i eller --install.

Exempel 5.2. Installation av paket med dpkg

# dpkg -i man-db_2.11.2-2_amd64.deb
(Reading database ... 166273 files and directories currently installed.)
Preparing to unpack man-db_2.11.2-2_amd64.deb ...
Unpacking man-db (2.11.2-2) over (2.11.2-2) ...
Setting up man-db (2.11.2-2) ...
Updating database of manual pages ...
man-db.service is a disabled or a static unit not running, not starting it.
Processing triggers for mailcap (3.70+nmu1) ...
Vi kan se de olika steg som dpkg utför, således kan vi veta vid vilket steg ett problem kan ha uppstått. Installationen kan också utföras i två etapper: uppackning först, och sen konfigurering. apt drar nytta av detta och kan på så vis minska antalet anrop på kommandot dpkg (och varje anrop är kostsam för systemet på grund av inläsning av databasen i minnet, i synnehet listan över redan installerade filer).

Exempel 5.3. Separat uppackning och konfiguration

# dpkg --unpack man-db_2.11.2-2_amd64.deb

(Reading database ... 166273 files and directories currently installed.)
Preparing to unpack man-db_2.11.2-2_amd64.deb ...
Unpacking man-db (2.11.2-2) over (2.11.2-2) ...
Processing triggers for mailcap (3.70+nmu1) ...
# dpkg --configure man-db
Setting up man-db (2.11.2-2) ...
Updating database of manual pages ...
man-db.service is a disabled or a static unit not running, not starting it.

Sometimes, dpkg will fail to install a package and return an error; if the user orders it to ignore this, it will only issue a warning; it is for this reason that we have the different --force-* options. The dpkg --force-help command, or documentation of this command, will give a complete list of these options. The most frequent error, which you are bound to encounter sooner or later, is a file collision. When a package contains a file that is already installed by another package, dpkg will refuse to install it. The following messages will then appear:
Unpacking libgdm (from .../libgdm_3.8.3-2_amd64.deb) ...
dpkg: error processing /var/cache/apt/archives/libgdm_3.8.3-2_amd64.deb (--unpack):
 trying to overwrite '/usr/bin/gdmflexiserver', which is also in package gdm3 3.4.1-9
I detta fallet, om du tror att ett utbyte av denna fil inte utgör en signifikant risk för systemets stabilitet (vilket det vanligtvis inte utgör), så kan du använda flaggan --force-overwrite som meddelar dpkg att ignorera detta felmeddelande och skriva över filen.
While there are many available --force-* options, only --force-overwrite is likely to be used regularly. These options only exist for exceptional situations, rarely encountered in Debian Stable. It is better to leave them alone as much as possible in order to respect the rules imposed by the packaging mechanism. Do not forget, these rules ensure the consistency and stability of your system.

5.4.2. Borttagning av Paket

Genom att åberopa dpkg med flaggan -r eller --remove, följt av ett namn på ett paket, så kommer paketet ifråga avinstalleras. Detta bottagande är dock inte komplett, alla konfigurationsfiler, undehållsskript, loggfiler (systemnivå) och andra användardata som tillhandahållts för eller av paketet kvarstår. På det sättet är den enkelt att inaktivera ett program genom att avinstallera det, och möjligheten kvarstår att snabbt kunna återinstallera med samma konfiguration. För att helt rensa ut allt som kan associeras med paketet, använd flaggan -P eller --purge följt av paketnamnet.

Exempel 5.4. Borttagning och fullständig rensning av paketet debian-cd

# dpkg -r debian-cd
(Reading database ... 228705 files and directories currently installed.)
Removing debian-cd (3.1.35) ...
# dpkg -P debian-cd
(Reading database ... 228049 files and directories currently installed.)
Purging configuration files for debian-cd (3.1.35) ...

5.4.3. Undersöka dpkg's databas och inspektera .deb filer

Before concluding this section, we will study dpkg options that query the internal database in order to obtain information. Giving first the long options and then corresponding short options (that will evidently take the same possible arguments) we cite
  • --listfiles package (or -L), which lists the files installed by this package;
  • --search file (or -S), which finds the package(s) containing the file;
  • --status package (or -s), which displays the headers of an installed package;
  • --list (or -l), which displays the list of packages known to the system and their installation status;
  • --contents file.deb (or -c), which lists the files in the Debian package specified;
  • --info file.deb (or -I), which displays the headers of this Debian package.

Exempel 5.5. Olika undersökningar med dpkg

$ dpkg -L base-passwd
/.
/usr
/usr/sbin
/usr/sbin/update-passwd
/usr/share
/usr/share/base-passwd
/usr/share/base-passwd/group.master
/usr/share/base-passwd/passwd.master
/usr/share/doc
/usr/share/doc/base-passwd
/usr/share/doc/base-passwd/README
/usr/share/doc/base-passwd/changelog.gz
/usr/share/doc/base-passwd/copyright
/usr/share/doc/base-passwd/users-and-groups.html
/usr/share/doc/base-passwd/users-and-groups.txt.gz
/usr/share/doc-base
/usr/share/doc-base/base-passwd.users-and-groups
/usr/share/lintian
/usr/share/lintian/overrides
/usr/share/lintian/overrides/base-passwd
/usr/share/man
/usr/share/man/de
/usr/share/man/de/man8
/usr/share/man/de/man8/update-passwd.8.gz
/usr/share/man/es
/usr/share/man/es/man8
/usr/share/man/es/man8/update-passwd.8.gz
/usr/share/man/fr
/usr/share/man/fr/man8
/usr/share/man/fr/man8/update-passwd.8.gz
/usr/share/man/ja
/usr/share/man/ja/man8
/usr/share/man/ja/man8/update-passwd.8.gz
/usr/share/man/man8
/usr/share/man/man8/update-passwd.8.gz
/usr/share/man/pl
/usr/share/man/pl/man8
/usr/share/man/pl/man8/update-passwd.8.gz
/usr/share/man/ru
/usr/share/man/ru/man8
/usr/share/man/ru/man8/update-passwd.8.gz
$ dpkg -S /bin/date
coreutils: /bin/date
$ dpkg -s coreutils
Package: coreutils
Essential: yes
Status: install ok installed
Priority: required
Section: utils
Installed-Size: 18062
Maintainer: Michael Stone <mstone@debian.org>
Architecture: amd64
Multi-Arch: foreign
Version: 9.1-1
Pre-Depends: libacl1 (>= 2.2.23), libattr1 (>= 1:2.4.44), libc6 (>= 2.34), libgmp10 (>= 2:6.2.1+dfsg1), libselinux1 (>= 3.1~)
Description: GNU core utilities
 This package contains the basic file, shell and text manipulation
 utilities which are expected to exist on every operating system.
 .
 Specifically, this package includes:
 arch base64 basename cat chcon chgrp chmod chown chroot cksum comm cp
 csplit cut date dd df dir dircolors dirname du echo env expand expr
 factor false flock fmt fold groups head hostid id install join link ln
 logname ls md5sum mkdir mkfifo mknod mktemp mv nice nl nohup nproc numfmt
 od paste pathchk pinky pr printenv printf ptx pwd readlink realpath rm
 rmdir runcon sha*sum seq shred sleep sort split stat stty sum sync tac
 tail tee test timeout touch tr true truncate tsort tty uname unexpand
 uniq unlink users vdir wc who whoami yes
Homepage: http://gnu.org/software/coreutils
$ dpkg -l 'b*'
Desired=Unknown/Install/Remove/Purge/Hold
| Status=Not/Inst/Conf-files/Unpacked/halF-conf/Half-inst/trig-aWait/Trig-pend
|/ Err?=(none)/Reinst-required (Status,Err: uppercase=bad)
||/ Name                       Version        Architecture Description
+++-==========================-==============-============-===================
un  backuppc                   <none>         <none>       (no description available)
un  balsa                      <none>         <none>       (no description available)
ii  baobab                     43.0-1         amd64        GNOME disk usage analyzer
un  base                       <none>         <none>       (no description available)
un  base-config                <none>         <none>       (no description available)
ii  base-files                 12.4+deb12u5   amd64        Debian base system miscellaneous files
ii  base-passwd                3.6.1          amd64        Debian base system master password and group files
ii  bash                       5.2.15-2+b2    amd64        GNU Bourne Again SHell
ii  bash-completion            1:2.11-6       all          programmable completion for the bash shell
[..]
$ dpkg -c /var/cache/apt/archives/bash_5.2.15-2+b2_amd64.deb
drwxr-xr-x root/root         0 2023-04-23 17:23 ./
drwxr-xr-x root/root         0 2023-04-23 17:23 ./bin/
-rwxr-xr-x root/root   1265648 2023-04-23 17:23 ./bin/bash
drwxr-xr-x root/root         0 2023-04-23 17:23 ./etc/
-rw-r--r-- root/root      1994 2023-04-23 17:23 ./etc/bash.bashrc
drwxr-xr-x root/root         0 2023-04-23 17:23 ./etc/skel/
-rw-r--r-- root/root       220 2023-04-23 17:23 ./etc/skel/.bash_logout
-rw-r--r-- root/root      3526 2023-04-23 17:23 ./etc/skel/.bashrc
-rw-r--r-- root/root       807 2023-04-23 17:23 ./etc/skel/.profile
drwxr-xr-x root/root         0 2023-04-23 17:23 ./usr/
drwxr-xr-x root/root         0 2023-04-23 17:23 ./usr/bin/
-rwxr-xr-x root/root      6865 2023-04-23 17:23 ./usr/bin/bashbug
-rwxr-xr-x root/root     14488 2023-04-23 17:23 ./usr/bin/clear_console
drwxr-xr-x root/root         0 2023-04-23 17:23 ./usr/share/
drwxr-xr-x root/root         0 2023-04-23 17:23 ./usr/share/debianutils/
drwxr-xr-x root/root         0 2023-04-23 17:23 ./usr/share/debianutils/shells.d/
-rw-r--r-- root/root        21 2023-04-23 17:23 ./usr/share/debianutils/shells.d/bash
drwxr-xr-x root/root         0 2023-04-23 17:23 ./usr/share/doc/
[..]
$ dpkg -I /var/cache/apt/archives/bash_5.2.15-2+b2_amd64.deb
 new Debian package, version 2.0.
 size 1490660 bytes: control archive=2972 bytes.
      77 bytes,     4 lines      conffiles
    1039 bytes,    27 lines      control
    4581 bytes,    65 lines      md5sums
     486 bytes,    24 lines   *  postinst             #!/bin/bash
     209 bytes,     5 lines   *  postrm               #!/bin/sh
     289 bytes,    22 lines   *  prerm                #!/bin/bash
 Package: bash
 Source: bash (5.2.15-2)
 Version: 5.2.15-2+b2
 Architecture: amd64
 Essential: yes
 Maintainer: Matthias Klose <doko@debian.org>
 Installed-Size: 7164
 Pre-Depends: libc6 (>= 2.36), libtinfo6 (>= 6)
 Depends: base-files (>= 2.1.12), debianutils (>= 5.6-0.1)
 Recommends: bash-completion (>= 20060301-0)
 Suggests: bash-doc
 Conflicts: bash-completion (<< 20060301-0)
 Replaces: bash-completion (<< 20060301-0), bash-doc (<= 2.05-1)
 Section: shells
 Priority: required
 Multi-Arch: foreign
 Homepage: http://tiswww.case.edu/php/chet/bash/bashtop.html
 Description: GNU Bourne Again SHell
  Bash is an sh-compatible command language interpreter that executes
  commands read from the standard input or from a file.  Bash also
  incorporates useful features from the Korn and C shells (ksh and csh).
  .
  Bash is ultimately intended to be a conformant implementation of the
  IEEE POSIX Shell and Tools specification (IEEE Working Group 1003.2).
  .
  The Programmable Completion Code, by Ian Macdonald, is now found in
  the bash-completion package.

5.4.4. dpkg's loggfil

dpkg loggar alla sina aktiviteter i /var/log/dpkg.log. Denna logg är extremt utförlig, eftersom den i detalj redovisar samtliga av alla de steg som ett paket som handhas av dpkg går igenom. Utöver att den erbjuder en möjlighet att spåra dpkg's beteende, är den framför allt en hjälp för att ge en historisk överblick över ett systems utveckling. Man kan finna exakt vid vilken tidpunkt som samtliga paket har installerats och/eller uppdaterats, vilket kan vara extremt användbart vid utredning av en ändring i systemets beteende. Vidare registreras alla versioner och det är enkelt att jämföra och koppla informationen med changelog.Debian.gz för paketen ifråga, eller till och med buggrapporter registrerade på nätet.

5.4.5. Support för Multi-Instruktionsuppsättning

Alla Debian-paket har ett fällt för instruktionsuppsättning i deras kontrollinformation. Detta fällt kan innehålla antingen "all" (för paket som är oberoende av instruktionsuppsättning) eller namnet på den instruktionsuppsättning som den är avsedd för (exempelvis “amd64”, “armhf”, …). I det senare fallet kommer dpkg, som standard, enbart acceptera att installera paketet ifall dess instruktionsuppsättning matchar värdsystemets instruktionsuppsättning så som det redovisas av dpkg --print-architecture.
Denna restriktion försäkrar att användaren inte kommer till en situation med installerade binära program som är översatt till fel instruktionsuppsättning. Allt hade varit perfekt om det inte varit för att (en del) datorer kan köra binära program för flera olika instruktionsuppsättningar, antingen naturligt (ett "amd64"-system kan köra binärer översatta till "i386") eller med hjälp av emulatorer.

5.4.5.1. Aktivera Multi-Instruktionsuppsättning

dpkg's support för multi-instruktionsuppsättning tillåter användare att definiera "främmande instruktionsuppsättningar" som kan installeras på nuvarande system. Detta utförs enkelt med dpkg --add-architecture så som i exemplet nedan. Det finns en motsvarande dpkg --remove-architecture för att ta bort stöd för en främmande instruktionsuppsättning, med det kan enbart användas om det inte finns något installerat paket kvarstående för denna instruktionsuppsättning.
# dpkg --print-architecture
amd64
# dpkg --print-foreign-architectures
# dpkg -i gcc-12-base_12.2.0-14_arm64.deb
dpkg: error: cannot access archive 'gcc-12-base_12.2.0-14_arm64.deb': No such file or directory
# dpkg --add-architecture arm64
# dpkg --add-architecture arm64
# dpkg --print-foreign-architectures
arm64
# dpkg -i gcc-12-base_12.2.0-14_arm64.deb
Selecting previously unselected package gcc-12-base:arm64.
(Reading database ... 166273 files and directories currently installed.)
Preparing to unpack gcc-12-base_12.2.0-14_arm64.deb ...
Unpacking gcc-12-base:arm64 (12.2.0-14) ...
Setting up gcc-12-base:arm64 (12.2.0-14) ...
# dpkg --remove-architecture arm64
dpkg: error: cannot remove architecture 'arm64' currently in use by the database
[..]
# dpkg --remove-architecture arm64
# dpkg --print-foreign-architectures
# 

5.4.5.2. Multi-Instruktionsuppsättningsrelaterade Ändringar

För att verkligen dra nytta av multi-instruktionsuppsättning och göra den användbar, behövde bibliotek packas om och flyttas till en instruktionsuppsättningsspecifik katalog så att flera kopior (som vänder sig till olika instruktionsuppsättningar) kan vara installerad samtidigt på samma system. Dylika uppdaterade paket innehåller sidhuvudsfälltet “Multi-Arch: same” i syfte att meddela pakethanteraren att paketen för de olika instruktionsuppsättningarna säkert kan samexistera på samma system (och att de olika paketen enbart kan uppfylla beroenden för andra paket av samma instruktionsuppsättning). De allra flesta bibliotek har omvandlats sedan introduktionen av multi-instruktionsuppsättning i Debian 7Wheezy, men det finns många bibliotek som sannolikt aldrig kommer omvandlas så länge inte någon specifikt begär det (genom en felrapport exempelvis).
$ dpkg -s gcc-12-base
dpkg-query: error: --status needs a valid package name but 'gcc-12-base' is not: ambiguous package name 'gcc-12-base' with more than one installed instance

Use --help for help about querying packages.
$ dpkg -s gcc-12-base:arm64 | grep ^Multi
Multi-Arch: same
$ dpkg -L libgcc-s1:amd64 |grep .so
/lib/x86_64-linux-gnu/libgcc_s.so.1
$ dpkg -S /usr/share/doc/gcc-12-base/copyright
gcc-12-base:amd64, gcc-12-base:arm64: /usr/share/doc/gcc-12-base/copyright
Det är värt att notera att paket med Multi-Arch: same måste ha sitt namn kvalificerad med sin instruktionsuppsättning för att vara entydigt identifierbar. De har också möjligheten att dela filer med andra instanser av samma paket, dpkg säkerställer att alla paket har i detalj identiska filer när de är delade. Sist men inte minst, alla instanser av samma paket behöver ha samma version. De behöver därför uppgraderas samtidigt.
Support för Multi-Instruktionsuppsättning tillför även några intressanta utmaningar kring hur beroenden hanteras. Att tillmötesgå ett beroende kräver antingen ett paket markerad “Multi-Arch: foreign” eller ett paket vars instruktionsuppsättning är desamma som det paket som framställer beroendet (i denna process att lösa beroenden anses instruktionsuppsättningsoberoende paket vara av samma instruktionsuppsättning som värden). Ett beroende kan också försvagas så att alla instruktionsuppsättningar tillåts uppfylla det, med uttrycket package:any, men utomstående paket kan enbart uppfylla ett sådant beroende ifall de är märkta “Multi-Arch: allowed”.