6.3. Gestion de paquetages

La gestion de paquetages est un ajout souvent demandé au livre LFS. Un gestionnaire de paquetages permet de conserver une trace des fichiers installés, simplifiant ainsi leur suppression ou leur mise à jour. Un gesjionnaire de paquetages gérera tant les fichiers binaires et de bibliothèque que l'installation des fichiers de configuration. Avant tout, NON—cette section ne parle pas d'un gestionnaire de paquetages particulier, elle n'en recommande pas non plus. Elle fait un tour des techniques les plus populaires pour indiquer comment elles fonctionnent. Le gestionnaire parfait de paquetages pourrait faire partie de ces techniques ou pourrait être une combinaison d'une ou plusieurs techniques. Cette section mentionne brièvement les problèmes pouvant survenir lors de la mise à jour des paquetages.

Parmi les raisons de l'absence d'un gestionnaire de paquetages mentionné dans LFS ou BLFS :

Des astuces ont été écrites sur le thème de la gestion de paquetages. Visitez le Projet des astuces et voyez celui qui satisfait vos besoins.

6.3.1. Problèmes de mise à jour

Un gestionnaire de paquetages facilite la mise à jour des nouvelles versions au moment de leur sortie. Généralement, les instructions dans les livres LFS et BLFS peuvent être utilisées pour les nouvelles versions. Voici quelques points à connaître pour une mise à jour de paquetages, spécifiquement sur un système en cours de fonctionnement

  • Il est recommandé, si un des outils de l'ensemble des outils (glibc, gcc, binutils) doit être mis à jour avec une nouvelle version mineure, de reconstruire LFS. Bien que vous pourriez être capable de ne pas reconstruire tous les paquetages dans leur ordre de dépendances. Nous ne vous le recommandons pas. Par exemple, si glibc-2.2.x a besoin d'être mis à jour vers glibc-2.3.x, il est préférable de reconstruire. Pour les mises à jour encore plus mineures, une simple réinstallation fonctionne généralement mais cela n'est pas garanti. Par exemple, mettre à jour de glibc-2.3.1 à glibc-2.3.2 ne causera aucun problème.

  • Si un paquetage contenant une bibliothèque partagée est mise à jour et si le nom de cette dernière est modifié, alors les paquetages liées dynamiquement à la bibliothèque devront être recompilés pour être liés à la nouvelle bibliothèque. (Notez qu'il n'y a aucun corrélation entre la version du paquetage et le nom de la bibliothèque.) Par exemple, considérez un paquetage foo-1.2.3 qui installe une bibliothèque partagée de nom libfoo.so.1. Disons que vous mettez à jour le paquetage avec une nouvelle version foo-1.2.4 qui installe une bibliothèque partagée de nom libfoo.so.2. Dans ce cas, tous les paquetages liés dynamiquement à libfoo.so.1 doivent être recompilés pour être liés à libfoo.so.2. Notez que vous ne devez pas supprimer les anciennes bibliothèques jusqu'à ce que les paquetages indépendants soient recompilés.

6.3.2. Techniques de gestion de paquetages

Ce qui suit est une liste de techniques habituelles de gestion de paquetages. Avant de prendre une décision sur un gestionnaire de paquetages, faites une recherche sur les différentes techniques et notamment leurs faiblesses.

6.3.2.1. Tout est dans ma tête !

Oui, c'est une technique de gestion de paquetages. Certains n'éprouvent pas le besoin d'un gestionnaire de paquetages parce qu'ils connaissent très bien les paquetages et connaissent les fichiers installés par chaque paquetage. Certains utilisateurs n'en ont pas besoin parce qu'ils planifient la reconstruction entière de LFS lorsqu'un paquetage est modifié.

6.3.2.2. Installer dans des répertoires séparés

C'est une gestion des paquetages tellement simple qu'elle ne nécessite aucun paquetage supplémentaire pour gérer les installations. Chaque paquetage est installé dans un répertoire séparé. Par exemple, le paquetage foo-1.1 est installé dans /usr/pkg/foo-1.1 et un lien symboique est créé vers /usr/pkg/foo-1.1. Lors de l'installation de la nouvelle version foo-1.2, elle est installée dans /usr/pkg/foo-1.2 et l'ancien lien symbolique est remplacé par un lien symbolique vers la nouvelle version.

Les variables d'environnement telles que PATH, LD_LIBRARY_PATH, MANPATH, INFOPATH et CPPFLAGS ont besoin d'être étendues pour inclure /usr/pkg/foo. Pour plus que quelques paquetages, ce schéma devient ingérable.

6.3.2.3. Gestion de paquetage par lien symbolique

C'est une variante de la technique précédente. Chaque paquetage est installé de façon similaire au schéma précédent. Mais au lieu de réaliser le lien symbolique, chaque fichier dispose d'un lien symbolique vers son équivalent dans la hiérarchie /usr. Ceci supprime le besoin d'étendre les variables d'environnement. Bien que les liens symboliques peuvent être créés par l'utilisateur, pour automatiser la création, certains gestionnaires de paquetages ont été écrit avec cette approche. Parmi les plus populaires se trouvent Stow, Epkg, Graft et Depot.

L'installation doit être faussée, de façon à ce que chaque paquetage pense qu'il est installé dans /usr alors qu'en réalité il est installé dans la hiérarchie /usr/pkg. Installer de cette manière n'est généralement pas une tâche triviale. Par exemple, considérez que vous installez un paquetage libfoo-1.1. Les instructions suivantes pourraient ne pas installer correctement le paquetage :

./configure --prefix=/usr/pkg/libfoo/1.1
make
make install

L'installation fonctionnera mais les paquetages dépendants pourraient ne pas lier libfoo comme vous vous y attenderiez. Si vous compilez un paquetage qui se lie à /usr/pkg/libfoo/1.1/lib/libfoo.so.1 au lieu de /usr/lib/libfoo.so.1 comme vous le prévoyez. La bonne approche est d'utiliser la stratégie DESTDIR pour fausser l'installation du paquetage. Cette approche fonctionne ainsi :

./configure --prefix=/usr
make
make DESTDIR=/usr/pkg/libfoo/1.1 install

La plupart des paquetages supportent cette approche mais elle pose problème à certains. Pour les paquetages non compatibles, vous pouvez soit les installer manuellement soit trouver plus simple d'installer les paquetages problématiques dans /opt.

6.3.2.4. Basé sur le temps

Avec cette technique, un fichier est balisé avec l'heure avant l'installation du paquetage. Après l'installation, une simple utilisation de la commande find avec les options appropriées peut générer une trace de tous les fichiers installés après que le fichier temps ne soit créé. install-log est un gestionnaire de paquetages écrit avec cette approche.

Bien que ce schéma a l'avantage d'être simple, il a deux inconvénients. Si à l'installation, les fichiers sont installés sans balise de temps autre que l'heure actuelle, ces fichiers ne seront pas suivis par le gestionnaire de paquetages. De plus, ce schéma peut seulement être utilisé lorsqu'un seul paquetage est installé à la fois. Les traces ne sont pas fiables si deux paquetages sont installés dans deux consoles différentes.

6.3.2.5. Tracer les scripts d'installation

Avec cette approche, les commandes que les scripts d'installation accomplissedt sont enregistrées. Il y a deux techniques que vous pouvez utiliser :

Vo1s pouvez initialiser la variable d'environnement LD_PRELOAD pour qu'elle pointe vers une bibliothèque à précharger avant l'installation. Lors de l'utilisation de cette dernière, cette bibliothèque trace les paquetages en cours d'installation en s'attachant eux-même aux différents exécutables comme cp, install, mv et trace les appels système qui modifient le système de fichiers. Pour que cette approche fonctionne, tous les exécutables ont besoin d'être liés dynamiquement sans bit suid ou sgid. Le préchargement de la bibliothèque pourrait causer quelques effets de bord involontaires lors de l'installation ; donc, réalisez quelques tests pour vous assurer que le gestionnaire de paquetages ne casse rien et trace bien tous les fichiers appropriés.

La seconde technique est d'utiliier strace, qui trace tous les appels du système fa´ijs pendant l'exécution des icripts d'installation.

6.3.2.6. Créer des archives de paquetages

Dans ce schéma, l'installation d'un paquetage est faussée dans un répertoire séparé comme décrit plus haut. Après l'installation, une archive du paquetage est créée en utilisant les fichiers installés. L'archive est ensuite utilisée pour installer le paquetage soit sur la machine locale soit même sur d'autres machines.

Cette approche est utilisée par la plupart des gestionnaires de paquetages trouvés dans les distributions commerciales. Les exemples de gestionnaires qui suivent cette approche sont RPM (qui est parfois requis par la Spécification de base de Linux Standard), pkg-utils, apt de Debian, et le système de portage de Gentoo. Une astuce décrivant comment adopter ce style de gestion de paquetages pour les systèmes LFS se trouve à http://www.linuxfromscratch.org/hints/downloads/files/fakeroot.txt.

6.3.2.7. Gestion basée sur les utilisateurs

Ce schéma, unique à LFS, a été décrit par Matthias Benkmann et est disponible sur le Projet des astuces. Dans ce schéma, chaque paquetage est installé en tant qu'utilisateur séparé dans les emplacements standards. Les fichiers appartenant à un paquetage sont facilement identifiés grâce à l'identifiant de l'utilisateur. Les fonctionnalités et avantages de cette approche sont trop complexes pour les décrire dans cette section. Pour plus de détails, voir l'astuce sur http://www.linuxfromscratch.org/hints/downloads/files/more_control_and_pkg_man.txt.