« Les paquets Slackware » : différence entre les versions

De Lea Linux
Aller à la navigation Aller à la recherche
Aucun résumé des modifications
Aucun résumé des modifications
Ligne 1 : Ligne 1 :
[[Category:Logiciels]]
[[Category:Logiciels]]
[[Catégorie:Slackware]]
= Les paquetages Slackware =
= Les paquetages Slackware =



Version du 8 novembre 2010 à 13:34


Les paquetages Slackware

Les paquetages Slackware
Où comment gérer ses tgz...

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 :

bash-2.05b$ pwd
/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 :

bash-2.05b$ ./configure --prefix=/usr/local
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
Note : ici, on utilise ./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).

Note : Certains Makefile n'utilise pas DESTDIR comme variable. Il faut parfois lire le INSTALL ou éditer le fichier Makefile pour connaitre la syntaxe exacte. A titre indicatif, une alternative courante prend la forme de 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 :

bash-2.05b$ pwd
/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)?
Note : Il est intéressant de "marquer" les paquets fait comme ne venant pas de la distribution d'origine. Par exemple, je mets "-ssk" dans chaque nom de paquet néocréé.

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.

tar-1.13: bchunk-1.1.1-i686-ssk.tar is the archive; not dumped
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).

Note : Les fichiers SlackBuild sont des scripts permettant d'automatiser la création d'un tgz (cf. paragraphe suivant).

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.

Note : Vérifiez de bien avoir les permissions d'exécution avant de lancer un SlackBuild. Sinon, faites un chmod 755 monlogiciel.SlackBuild
Note 2 : Certains SlackBuild patchent au passage les sources, vous avez donc besoin de mettre le(s) patch(s) dans le même répertoire que le SlackBuild et les sources.

Anatomie d'un SlackBuild

Un SlackBuild ouvert avec un éditeur de texte donne quelque chose comme :

#!/bin/sh

# 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.

Note : Pour le "marquage", vous pouvez utiliser la variable BUILD, exemple : 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.

PACKAGE DESCRIPTION:
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://swaret.sourceforge.net/. 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:
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) :

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.

root@gedphoenix:/etc# swaret --update
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.

root@gedphoenix:/etc# swaret --install fluxbox
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é.

Note : Attention, Swaret upgrade dans l'ordre alphabétique. Donc si vous mettez plusieurs paquetages à jour, il risque d'en installer dans le mauvais ordre (certains paquetages tels que la glibc sont sensibles à ce sujet). Et il ne respecte pas la méthodologie de Patrick (Patrick Volkerding, le mainteneur de la Slackware) pour l'upgrade du système.

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 :

#!/bin/bash
# /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 ;) ...

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.



@ Retour à la rubrique Logiciels

Copyright

Copyright © 16/01/2004, GEDsismik

Creative Commons License
Creative Commons Attribution iconCreative Commons Share Alike iconCreative Commons Noncommercial
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/