« Les paquets Slackware » : différence entre les versions
(conversion de la documentation originale de Léa par HTML::WikiConverter) |
(conversion de la documentation originale de Léa par HTML::WikiConverter) |
||
Ligne 193 : | Ligne 193 : | ||
<div class="merci">Cette page est issue de la documentation 'pré-wiki' de Léa a été convertie avec HTML::WikiConverter. Elle fut créée par GEDsismik le 16/01/2004.</div> | <div class="merci">Cette page est issue de la documentation 'pré-wiki' de Léa a été convertie avec HTML::WikiConverter. Elle fut créée par GEDsismik le 16/01/2004.</div> | ||
= Copyright = | |||
Copyright © 16/01/2004, GEDsismik | |||
{{CC-BY-NC-SA}} |
Version du 7 septembre 2005 à 12:11
Les paquetages Slackware
Chaque distribution a ses spécificités. Parmi celles-ci se retrouve le système de paquetage. Les paquetages Slackware sont des fichiers .tgz, c'est-à-dire compressés comme un .tar.gz. Ils contiennent, le plus souvent, les binaires du logiciel avec ses fichiers de configuration plus un répertoire install
pouvant contenir la description du paquetage et le script à exécuter après l'installation. L'une des particularités du tgz Slackware, c'est qu'il ne prend pas en compte les dépendances avec les autres paquetages. Dans cet article, nous allons vous présenter les outils Slackware de gestion de paquetage ainsi que Swaret, outils d'installation/mise à jour à la urpm.
Pkgtools, quoi qu'est-ce ?
Pkgtools est un paquetage contenant des outils destinés à la gestion des paquetages Slackware. Ces outils sont tous des scripts bash jouant un rôle précis.
Installation, suppression de paquetage
installpkg
installpkg installe un paquetage. La syntaxe est la suivante : installpkg <nomdupaquetage.tgz>
. Pour information, installpkg stocke la liste des paquetages installés ainsi que la description des paquetages dans /var/log/packages/.
removepkg
removepkg désinstalle un paquetage. La syntaxe est la suivante : removepkg <nomdupaquetage>
. Si vous n'êtes pas sûr de la syntaxe complète, essayez ls /var/log/packages/
. Pour information, removepkg stocke la liste des paquetages désinstallés dans /var/log/removed_packages/.
upgradepkg
upgradepkg met à jour un paquetage installé. La syntaxe est la suivante : upgradepkg <nomdupaquetage.tgz>
. Pour information, upgradepkg stocke la liste des paquetages mis-à-jour avec celle des paquetages installés dans /var/log/packages/.
pkgtool
pkgtool est une interface "semi-graphique" en ncurse permettant la gestion des paquetages. Il utilise installpkg, removepkg et upgradepkg.
Création d'un paquetage
La gestion des paquetages est très intéressante (même si la gestion des dépendances n'existe pas avec pkgtools) mais il n'existe pas toujours de paquetage Slackware pour toutes les applications. La compilation s'avère donc nécessaire. Le mieux dans ce cas est de faire son propre paquetage. Une éventuelle désinstallation sera ainsi plus simple et plus propre.
Configure
La "technique" de compilation, la plus simple est le classique "configure"-"make"-"make install". Seulement, voilà, on va faire plus complet. Commencez par créer un répertoire qui devra contenir les fichiers compilés (souvent, je prends le répertoire dans lequel j'ai décompressé le logiciel à compiler + /tgz). Dans ce répertoire, créez ./usr/local (pour que le paquetage s'installe dans /usr/local, mettez ./usr pour qu'il s'installe dans /usr). Exemple :
/download/compil/bchunk-1.1.1
bash-2.05b$ mkdir tgz
bash-2.05b$ ls
bchunk bchunk-1.1.1.lsm bchunk.spec COPYING README
bchunk.1 bchunk.c ChangeLog Makefile tgz
bash-2.05b$
Ensuite, il faut faire un configure avec toutes vos options classiques : Exemple :
checking for a BSD-compatible install... /usr/bin/ginstall -c
checking whether build environment is sane... yes
checking for gawk... gawk
checking whether make sets $(MAKE)... yes
checking for sed... /usr/bin/sed
checking for gcc... gcc
checking for C compiler default output... a.out
checking whether the C compiler works... yes
./configure --prefix=/usr/local
pour être sur que le paquetage s'installera dans /usr/local plutôt qu'ailleurs. Compilation
Ensuite, nous allons compiler et installer le logiciel dans le répertoire choisi. Vous pouvez donc faire make
. make install DESTDIR=/download/compil/bchunk-1.1.1/tgz
permet d'installer le programme dans le repertoire que l'on veut (en utilisateurs, pas besoin d'être root : il n'est pas utilisé de répertoire interdit en écriture).
make install prefix=/download/compil/bchunk-1.1.1/tgz/usr/local
. Peaufinage
Ce paragraphe n'est pas obligatoire mais préférable. Il est intéressant de compresser les pages de man ( gzip -9 /download/compil/bchunk-1.1.1/tgz/usr/man/man?/*
et gzip -9 /download/compil/bchunk-1.1.1/tgz/usr/local/man/man?/*
) et d'ajouter des pages infos ou des howtos à cette étape de la création. Autre commande à noter : chown -R root.bin /download/compil/bchunk-1.1.1/tgz/*
pour mettre les fichiers crés du groupe bin (afin de respecter les pratiques habituelles des paquetages Slackware).
Création du tgz
Passez ensuite dans le répertoire préfixe (moins /usr/local) et passez en root (makepkg n'est utilisable qu'en root). Tapez ensuite makepkg <nomdupaquetage.tgz>
. Exemple :
/download/compil/bchunk-1.1.1/tgz
bash-2.05b$ su
Mot de passe:
bash-2.05b# makepkg bchunk-1.1.1-i686-ssk.tgz
Slackware package maker, version 2.1.
Searching for symbolic links:
No symbolic links were found, so we won't make an installation script.
You can make your own later in ./install/doinst.sh and rebuild the
package if you like.
This next step is optional - you can set the directories in your package
to some sane permissions. If any of the directories in your package have
special permissions, then DO NOT reset them here!
Would you like to reset all directory permissions to 755 (drwxr-xr-x) and
directory ownerships to root.root ([y]es, [n]o)?
On vous demandera peut-être (comme ci-dessus) si vous voulez changer les permissions des fichiers ou remplacer les liens symboliques créés par make install
par des lignes supplémentaires dans le script. Je réponds oui à toutes ces questions personnellement. Hop ! On valide la réponse.
Gzipping bchunk-1.1.1-i686-ssk.tar...
Renaming bchunk-1.1.1-i686-ssk.tar.gz to bchunk-1.1.1-i686-ssk.tgz...
Package creation complete.
bash-2.05b# ls
bchunk-1.1.1-i686-ssk.tgz usr
Vous voilà donc avec votre paquetage. Il peut être installé, supprimé ou mis-à-jour avec les outils précédemment vus (installpkg, removepkg, upgradepkg).
Création d'un SlackBuild
"Pffffiou... ca va etre contraignant si j'dois me rappeler comment j'ai compilé à la prochaine version..." C'est vrai que parfois, on a beaucoup de paramètres à passer au ./configure
ou des manipulations à faire après. Pour ça, il existe des scripts appelés SlackBuild. Vous pouvez trouver les SlackBuild qui ont servi aux paquetages officiels sur le CD Source ou dans le repértoire /source du ftp Slackware. Vous pouvez aussi faire vos propres SlackBuild pour générer vos propres paquetages.
Utilisation d'un SlackBuild
Un SlackBuild est un script bash avec pour nom monlogiciel.SlackBuild
. Il vous suffit de le mettre dans le même répertoire que le .tar.bz2 (ou parfois le .tar.gz) du logiciel à compiler et de l'exécuter en root. Il se charge de tout : du dézippage à la formation du .tgz en passant par le configure et la compilation.
chmod 755 monlogiciel.SlackBuild
Anatomie d'un SlackBuild
Un SlackBuild ouvert avec un éditeur de texte donne quelque chose comme :
# Définition des répertoire à utiliser
CWD=`pwd`
PKG=$PWD/tgz
# Définition de la version
VERSION=4.9.10
ARCH=i486
BUILD=1
# On efface les répertoires d'une précédente création
rm -rf $PKG
mkdir -p $PKG
cd /tmp
rm -rf centericq-$VERSION
# On décompresse
tar xjvf $CWD/centericq-$VERSION.tar.bz2
cd centericq-$VERSION
chown -R root.root .
# On configure
./configure --prefix=/usr/local \
i486-slackware-linux
# On compile
make
make install DESTDIR=$PKG
# Compression des pages de man (facultatif)
gzip -9 $PKG/usr/man/man?/*
gzip -9 $PKG/usr/local/man/man?/*
# Changement de permission
chown -R root.bin $PKG/usr/local/bin
chown -R root.bin $PKG/usr/bin
# On insère les commentaires si il y en a
mkdir -p $PKG/install
cat $CWD/slack-desc > $PKG/install/slack-desc
# On fait le tgz en lui-même
cd $PKG
makepkg -l y -c n ../centericq-$VERSION-$ARCH-$BUILD.tgz
A vous d'adapter ça au logiciel que vous voulez compiler.
BUILD=ssk
Les slack-desc
Les slack-desc sont des fichiers contenant la description du paquetage. Ils sont a placer dans même répertoire que le Slackbuild auquel il contribue. Ils sont de la forme :
# HOW TO EDIT THIS FILE: # The "handy ruler" below makes it easier to edit a package description. Line # up the first '|' above the ':' following the base package name, and the '|' # on the right side marks the last column you can put a character in. You must # make exactly 11 lines for the formatting to be correct. It's also # customary to leave one space after the ':'. |-----handy-ruler------------------------------------------------------| generic: generic generic: generic: Ma description du logiciel generic generic: generic: generic:
Leur format est le format texte standard respectant certaines règles :
- Ne dépasser 11 lignes
- Chaque ligne doit être comprise entre les deux | du handy-ruler (un petit copier-coller peut vous être utile)
- Chaque ligne doit commencer par le nom du paquetage suivi de : et d'un espace (exempe :
gcc:
)
Swaret, quoi qu'est-ce ?
Swaret est un logiciel de gestion de paquetage sous Linux Slackware. A la manière d'apt-get (debian), urpm (mandrake) ou emerge (gentoo), il permet d'installer ou de mettre à jour à partir d'un miroir.
swaret: swaret (SlackWARE Tool)
swaret:
swaret: swaret Upgrades, Installs, Re-Installs, Downloads,...
swaret: Packages, Patches, Sources (with Build Scripts) and much more!
swaret: swaret includes Dependency Support, which Tracks and Fixes missing
swaret: Libraries. It uses several Slackware Linux Mirrors through
swaret: http/ftp/rsync or a Local Repository. swaret has also Repository
swaret: Support to create a Repository of Slackware Packages which will
swaret: allow swaret to use it with the known --ACTIONS.
swaret: swaret can also use 3rd-party Slackware Packages available on
swaret: LinuxPackages DOT NET and other Repository Sites.
swaret: swaret has also Internationalization (i18n) Support.
swaret:
swaret: swaret is written and maintained by Luc Cottyn and Michael G. Manry.
swaret:
swaret: For more information, see http://www.swaret.org
swaret:
L'essentiel : Swaret met à jour, installe, réinstalle, télécharge.. les paquetages, patches, sources (avec scripts de construction) et bien plus. Swaret inclut un support des dépendances, avec recherche et installation des bibliothèques manquantes. Il utilise plusieurs miroirs Slackware Linux à travers http/ftp/rsync ou encore un répertoire local.
Installation de Swaret
Téléchargement
Vous pouvez télécharger Swaret sur http://www.swaret.org/. A l'heure où j'écris ces lignes, la dernière version est la 1.6.2-noarch-1.
Installation du paquetage
Vous récupérez un paquetage Slackware en tgz. L'installation se déroule comme pour tout tgz en tapant (en root) installpkg swaret-1.6.2-noarch-1.tgz
dans le répertoire où le fichier a été téléchargé (pour une mise à jour, upgradepkg swaret-1.6.2-noarch-1.tgz
). Pour information, le binaire se loge dans /usr/sbin. Cela pour rappeler que Swaret ne s'utilise qu'en root (le root étant le seul utilisateur pouvant installer ou mettre à jour des paquetages).
Configuration
La configuration de Swaret comporte deux fichiers (contenus dans /etc) : /etc/swaret.lang (la configuration de langue) et /etc/swaret.conf (la configuration des miroirs et des différentes options).
Langue
C'est parfois irritant d'utiliser un logiciel dans la langue de Shakespeare. Heureusement, Swaret possède maintenant une traduction, comme l'indique l'installation du tgz :
swaret: ! NEW CONFIG FILE FOR REPOSITORY SUPPORT !
swaret: YOU MUST EDIT /etc/swaret.conf.new! (man swaret.conf)
swaret: Rename it to /etc/swaret.conf and start using swaret.
swaret:
swaret: ! NEW LANGUAGE FILE FOR INTERNATIONALIZATION (i18n) !
swaret: YOU CAN COPY /usr/share/swaret-1.6.0/swaret.lang.LANGUAGE to
swaret: /etc/swaret.lang and start using swaret.
swaret: Language Files available at http://www.swaret.org/?menu=i18n
swaret:
swaret: Take a look to the Documentation Files found in:
swaret: /usr/doc/swaret-1.6.0/
swaret:
Ça veut dire quoi ? Ça veut dire qu'on peut avoir Swaret en français en tapant (en root) : cp /usr/share/swaret-1.6.0/swaret.lang.FRANCAIS /etc/swaret.lang
.
Miroir
Le début du fichier /etc/swaret.conf contient une liste de miroirs sous la forme (extrait) :
ROOT=ftp://ftp.slackware.no/pub/linux/slackware/slackware-current
ROOT=ftp://ftp.slackware.at/slackware-current
ROOT=ftp://ftp.planetmirror.com/pub/slackware/slackcware-current
ROOT=http://www.slackware.no/slackware/slackware-current
Ce sont les sites sur lesquels Swaret ira chercher les paquetages à installer ou mettre à jour. Vous pouvez ajouter vos propres miroirs ou changer l'ordre (Swaret les essaye dans l'ordre). Un simple dièse en début de ligne la désactive. Personnellement, je n'ai rien touché si ce n'est pour ajouter mon serveur en local.
Utilisation de Swaret
Tout d'abord, je vous conseille de mettre à jour la liste des paquetages que Swaret connaît. Pour ce faire, très simple, tapez en root : swaret --update
. Swaret va chercher la liste des paquetages sur les miroirs. Remarque : toutes les commandes se font en root.
swaret 1.6.0-5
[ http://192.168.254.222/update/slackware ]
### Téléchargement de la liste des fichiers CHECKSUMS... FINI !
### Téléchargement de la liste des fichiers FILELIST... FINI !
### Téléchargement de la liste des fichiers PACKAGES pour les paquetages... FINI !
### Téléchargement de la liste des fichiers PACKAGES pour les paquetages additionnels... FINI !
### Téléchargement de ChangeLog... FINI !
=> Génération des listes de fichiers... FINI !
Installation avec Swaret
Vous pouvez obtenir la liste des paquetages à installer en faisant swaret --list -n
(-n pour paquetages non installés). L'installation se fait simplement en tapant swaret --install <mot-clé>
(où mot-clé est un morceau du nom du paquetage). Swaret liste alors les paquetages dont le nom contient la chaîne de caractères proposée et vous demande pour chaque paquetage si vous voulez l'installer.
swaret 1.6.0-5
Listage des paquetages disponibles appropriés au mot-clé : fluxbox...
fluxbox-0.1.14-i386-1 (348 ko)
fluxbox-0.9.6pre1-i486-1 (493 ko)
Le paquetage fluxbox-0.9.6pre1-i486-1 est déjà installé !
Listage des différents versions du paquetage 'fluxbox'...
> fluxbox-0.1.14-i386-1
Trouvé une version installée du paquetage 'fluxbox': fluxbox-0.9.6pre1-i486-1
Êtes-vous sur de vouloir installer fluxbox-0.1.14-i386-1? (o/n/A/Q): [o]
En cas de dépendances, Swaret vous demandera si vous voulez installer les paquetages dont dépend celui que vous avez demandé.
Mise-à-jour avec Swaret
Vous pouvez obtenir la liste des paquetages à installer en faisant swaret --list -u
(-u pour paquetages à "upgrader"). L'installation se fait simplement en tapant swaret --upgrade <mot-clé>
(où mot-clé est un morceau du nom du paquetage). Swaret liste alors les paquetages dont le nom contient la chaîne de caractère proposée et vous demande pour chaque paquetage si vous voulez le mettre à jour. En cas de dépendances, Swaret vous demandera si vous voulez installer les paquetages dont dépend celui que vous avez demandé.
Mise-à-jour automatique
Ce qui peut être sympa, c'est que swaret se mette à jour et mette à jour le système tout seul. Pour ca, vous pouvez réaliser le petit script suivant :
# /sbin/swaretupdate
swaret --update
swaret --upgrade -a
et l'ajouter dans la crontab
: 30 5 * * * /sbin/swaretupdate
(pour le lancer tout les jours à 5h30)
Conclusion sur Swaret
Swaret est un excellent outil de gestion de paquetage, tout à fait comparable à apt-get, urpm ou encore emerge. Pour plus d'informations, tapez man swaret
ou attendez une mise à jour du présent document.
En conclusion
Vous avez maintenant le panel de possibilités pour gérer à votre gré les paquetages de votre système et même distribuer les vôtres. En espérant que cela vous sera utile, have fun ;) ...
Copyright
Copyright © 16/01/2004, GEDsismik
Ce document est publié sous licence Creative Commons Attribution, Partage à l'identique, Contexte non commercial 2.0 : http://creativecommons.org/licenses/by-nc-sa/2.0/fr/ |