En tant qu'administrateur de système Debian, vous allez régulièrement manipuler des paquets (fichiers .deb
) car ils abritent des ensembles fonctionnels cohérents (applications, documentations...) dont ils facilitent l'installation et la maintenance. Mieux vaut donc savoir de quoi ils sont constitués et comment on les utilise.
Vous trouverez ci-après la description des structures et contenus des paquets de type « binaire », puis « source ». Les premiers sont les fichiers directement utilisables par dpkg
alors que les seconds contiennent les codes sources des programmes ainsi que les instructions pour créer les paquets binaires.
5.1. Structure d'un paquet binaire
Le format d'un paquet Debian est conçu de telle sorte que son contenu puisse être extrait sur tout système Unix disposant des commandes classiques ar
, tar
et xz
parfois xz
ou bzip2
. Cette propriété en apparence anodine est importante du point de vue de la portabilité et de la récupération en cas de catastrophe.
Imagine, for example, that you mistakenly deleted the
dpkg
program, and that you could thus no longer install Debian packages.
dpkg
being a Debian package itself, it would seem your system would be done for... Fortunately, you know the format of a package and can therefore
download the
.deb
file of the
dpkg package and install it manually (see sidebar
OUTILS dpkg
, APT
et ar
). If by some misfortune one or more of the programs
ar
,
tar
or
gzip
/
xz
/
bzip2
have disappeared, you will only need to copy the missing program from another system (since each of these operates in a completely autonomous manner, without dependencies, a simple copy will suffice). If your system suffered some even more outrageous misfortune, and even these don't work (maybe the deepest system libraries are missing?), you should try the static version of
busybox
(provided in the
busybox-static package), which is even more self-contained, and provides subcommands such as
busybox ar
,
busybox tar
and
busybox xz
.
Examinons le contenu d'un fichier .deb
:
$
ar t dpkg_1.21.22_amd64.deb
debian-binary
control.tar.gz
data.tar.xz
$
ar x dpkg_1.21.22_amd64.deb
$
ls
control.tar.gz data.tar.xz debian-binary dpkg_1.21.22_amd64.deb
$
tar tJf data.tar.xz | head -n 16
./
./etc/
./etc/alternatives/
./etc/alternatives/README
./etc/cron.daily/
./etc/cron.daily/dpkg
./etc/dpkg/
./etc/dpkg/dpkg.cfg
./etc/dpkg/dpkg.cfg.d/
./etc/logrotate.d/
./etc/logrotate.d/alternatives
./etc/logrotate.d/dpkg
./lib/
./lib/systemd/
./lib/systemd/system/
./lib/systemd/system/dpkg-db-backup.service
$
tar tJf control.tar.xz
./
./conffiles
./control
./md5sums
./postinst
./postrm
./prerm
$
cat debian-binary
2.0
Comme vous le voyez, l'archive ar
d'un paquet Debian est constituée de trois fichiers:
debian-binary
This is a text file which simply indicates the version of the .deb
file package format version. In Debian Bookworm it is still version 2.0.
control.tar.xz
Ce fichier d'archive rassemble les diverses méta-informations disponibles, comme le nom et la version du paquet, mais également certains scripts à exécuter avant, pendant ou après son installation. Certaines des méta-informations leur permettent de déterminer s'il est ou non possible de l'installer ou de le désinstaller, par exemple en fonction de la liste des paquets déjà présents sur la machine ou des fichiers qui ont été modifiés en local.
data.tar.xz
, data.tar.bz2
, data.tar.gz
Cette archive contient tous les fichiers à extraire du paquet ; c'est là que sont stockés les exécutables, les bibliothèques, la documentation, etc. Les paquets peuvent employer des formats de compression différents, auquel cas le fichier sera nommé différemment par xz
, bzip2
ou gzip
.