Product SiteDocumentation Site

5.4. Manipolazione dei pacchetti con dpkg

dpkg è il comando di base per gestire i pacchetti Debian sul sistema. Se si hanno dei pacchetti .deb, è dpkg che permette l'installazione o l'analisi del loro contenuto. Ma questo programma ha solo una visione parziale dell'universo Debian: conosce cosa è installato sul sistema e ciò che è dato sulla riga di comando, ma non conosce nulla degli altri pacchetti disponibili. Perciò, fallirà se una dipendenza non è soddisfatta. Strumenti come apt e aptitude, al contrario, creano un elenco di dipendenze da installare il più automaticamente possibile.

5.4.1. Installazione dei pacchetti

dpkg è, soprattutto, uno strumento per installare un pacchetto Debian già disponibile (perché non scarica niente). Per fare ciò, si usa la sua opzione -i oppure --install.

Esempio 5.2. Installazione di un pacchetto con 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) ...
Si possono vedere i differenti passi eseguiti da dpkg; sappiamo, perciò, a quale punto si è verificato un errore. L'installazione può anche essere effettuata in due stadi: prima lo spacchettamento, poi la configurazione. apt si avvantaggia di ciò, limitando il numero di chiamate a dpkg (dal momento che ogni chiamata è onerosa a causa del caricamento del database in memoria, specialmente l'elenco dei file già installati).

Esempio 5.3. Spacchettamento e configurazione separati

# 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 libisc52 (from .../libisc52_1%3a9.6.ESV.R1+dfsg-0+lenny2_amd64.deb) ...
dpkg : error processing /var/cache/apt/archives/libisc52_1%3a9.6.ESV.R1+dfsg-0+lenny2_amd64.deb (--unpack) :
 trying to overwrite "/usr/lib/libisc.so.50", which is also in package libisc50 1:9.6.1.dfsg.P1-3
In questo caso, se si pensa che sostituire questo file non sia un rischio significativo per la stabilità del sistema (e solitamente è così), si può usare l'opzione --force-overwrite, che dice a dpkg di ignorare questo errore e di sovrascrivere il file.
Anche se ci sono molte opzioni --force-*, è probabile che solo --force-overwrite sia usata regolarmente. Queste opzioni esistono solamente per situazioni eccezionali, raramente incontrate in Debian Stable. È meglio lasciarle stare il più possibile per rispettare le regole imposte dal meccanismo dei pacchetti. Non dimentichiamoci che queste regole assicurano la coerenza e la stabilità del sistema.

5.4.2. Rimozione di pacchetti

Invocare dpkg con l'opzione -r o --remove, seguita dal nome del pacchetto, rimuove tale pacchetto. Questa rimozione, comunque, non è completa: rimangono tutti i file di configurazione, gli script del manutentore, i file di log (di sistema) e altri dati utente gestiti dal pacchetto. In questo modo la disattivazione del programma può essere facilmente eseguita disinstallandolo ed è ancora possibile reinstallarlo rapidamente con la stessa configurazione. Per rimuovere completamente tutto ciò che è associato ad un pacchetto, utilizzare l'opzione -P o --purge, seguita dal nome del pacchetto..

Esempio 5.4. Rimozione ed eliminazione completa del pacchetto 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. Interrogazione del Database di dpkg ed Ispezione dei File .deb

Prima di concludere questa sezione, studieremo le opzioni di dpkg che interrogano il database interno per ottenere informazioni. Mostreremo prima le opzioni lunghe e poi le corrispondenti opzioni brevi (che evidentemente prenderanno gli stessi possibili argomenti) come:
  • --listfiles pacchetto (o -L), che elenca i file installati da questo pacchetto;
  • --search file (o -S), che trova i pacchetti contenenti il file;
  • --status pacchetto (o -s), che visualizza le intestazioni di un pacchetto installato;
  • --list (o -l), che visualizza l'elenco dei pacchetti noti al sistema ed il loro stato di installazione;
  • --contents file.deb (o -c), che elenca i file del pacchetto Debian specificato;
  • --info file.deb (o -I), che visualizza le intestazioni di questo pacchetto Debian.

Esempio 5.5. Varie richieste con 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. File di registro di dpkg

Una funzionalità introdotta recentemente in dpkg è che mantiene un registro di tutte le proprie azioni in /var/log/dpkg.log. Questo registro è estremamente prolisso, dal momento che contiene dettagli di ciascun stato attraverso cui passano i pacchetti gestiti da dpkg. Oltre a offrire un modo per tenere traccia del comportamento di dpkg, ciò aiuta, soprattutto, a mantenere una cronologia dello sviluppo del sistema: si può trovare il momento esatto in cui ciascun pacchetto è stato installato o aggiornato e queste informazioni possono essere estremamente utili nel comprendere un recente cambiamento di comportamento. Inoltre, siccome tutte le versioni sono registrate, è facile incrociare queste informazioni con il changelog.Debian.gz dei pacchetti in questione o anche con le segnalazioni di bug online.

5.4.5. Supporto Multi-Arch

Tutti i pacchetti Debian hanno un campo Architecture nelle loro informazioni di controllo. Questo campo può contenere tutti “all” (per i pacchetti indipendenti dalle architetture) oppure il nome dell'architettura per la quale è sviluppato il pacchetto (come “amd64”, “armhf”, …). In quest'ultimo caso, per impostazione predefinita, dpkg accetterà di installare il pacchetto solo se la sua architettura corrisponde a quella dell'host come restituito da dpkg --print-architecture.
Questa restrizione assicura che gli utenti non finiscano con binari compilati per un'architettura sbagliata. Tutto sarebbe perfetto, se non fosse che (alcuni) i computer possono eseguire binari per architetture multiple, sia nativamente (un sistema "amd64" può eseguire binari "i386") che attraverso emulatori.

5.4.5.1. Abilitazione Multi-Arch

Il supporto multi-arch di dpkg consente agli utenti di definire le "architetture esterne" che possono essere installate sul sistema corrente. Questo può essere fatto semplicemnete con dpkg --add-architecture come nell'esempio qui sotto. C'è un comando corrispondente per rimuovere il supporto ad un'architettura esterna che è dpkg --remove-architecture, ma può essere utilizzato solo quando non rimangono pacchetti di questa archietttura.
# 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. Variazioni Relative a Multi-Arch

Per rendere multi-arch realmente utile ed utilizzabile, le librerie sono state riassemblate e spostate in una directory specifica per l'architettura in modo che possano essere installate, contemporaneamente, più copie (specifiche per diverse architetture). Tali pacchetti aggiornati contengono il campo header “Multi-Arch: same” per dire al sistema dei pacchetti che le varie architetture possono essere installate, insieme, in sicurezza (e che quei pacchetti possono soddisfare in modo sicuro solo le dipendenze dei pacchetti della stessa architettura). Le librerie più importanti sono state convertite dall'introduzione di multi-arch in Debian 7 Wheezy, ma ci sono molte librerie che, probabilmente, non saranno mai convertite a meno che qualcuno non lo richieda specificamente (per esempio attraverso una segnalazione di bug).
$ 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
Vale la pena notare che i pacchetti Multi-Arch: same devono avere i nomi che identificano le loro architetture per essere identificati senza ambiguità. Essi hanno anche la possibilità di condividere i file con altre istanze dello stesso pacchetto; dpkg assicura che tutti i pacchetti abbiano dei file identici bit-per-bit quando sono condivisi. Infine, tutte le istanze di un pacchetto devono avere la stessa versione. Essi devono quindi essere aggiornati insieme.
Il supporto multi-Arch portacon sè anche alcune sfide interessanti nel modo in cui sono gestite le dipendenze. Soddisfare una dipendenza richiede o un pacchetto contrassegnato come “Multi-Arch: foreign” o un pacchetto la cui architettura corrisponde a quella del pacchetto del quale dichiara la dipendenza (in questo processo di risoluzione delle dipendenze, i pacchetti architettura-indipendenti si presume che siano della stessa architettura dell'host). Una dipendenza può anche essere indebolita per consentire a qualsiasi architettura di soddisfarla, con la sintassi package:any, ma i pacchetti esterni sono in grado di soddisfarla solo se sono contrassegnati come “Multi-Arch: allowed”.