Ceci est une ancienne révision du document !



P-Builder, ou comment bien construire des paquets

Ce document décrit les étapes nécessaires pour mettre en place un environnement de construction sain pour construire des paquets Ubuntu. Cet outil est recommandé pour les mainteneurs Ubuntu comme pour toute personne utilisant Ubuntu et intéressée par la construction des paquets.

Il est possible de construire les paquets sans utiliser P-Builder, mais cela nécessite d'avoir installé au préalable sur votre système toutes les dépendances pour le compiler.

Installez le paquet pbuilder puis générez l'environnement pbuilder avec la commande :

sudo pbuilder --create
Cette commande aura pour effet de créer un environnement isolé de votre système, appelé « chroot ». Cet environnement est en fait l'image du système tout frais après installation. En utilisant pbuilder pour construire vos paquets, vous serez alors sûr que le paquet s'installe bien sur tous les systèmes, même une Ubuntu venant d'être installée et sur laquelle l'utilisateur n'a installé aucun paquet supplémentaire.

Construire le paquet « mon-paquet » se fait avec la commande suivante :

sudo pbuilder --build mon-paquet_1.0.dsc
Le fichier .dsc est une partie du paquet source - que pbuilder va utiliser pour construire le paquet binaire - est généré avec la commande debuild. Ceci est expliqué en détails dans la page de tutoriel traitant de la création de paquets

Le ou les paquets seront disponibles dans le dossier /var/cache/pbuilder/result/

Si vous obtenez l'erreur "debootstrap does not exist", installez debootstrap ou exécutez pbuilder avec l'option --debootstrap cdebootstrap (vous avez probablement cdebootstrap installé).

Il est recommandé de mettre à jour votre chroot avant chaque construction. Pour ce faire, utilisez la commande :

sudo pbuilder update

éditez le fichier /etc/pbuilderrc et décommentez la ligne

COMPONENTS="main restricted universe multiverse"

À chaque modification de votre pbuilder, il faut le mettre à jour en prenant en compte la nouvelle configuration :

sudo pbuilder update --override-config

Si vous êtes désireux de participer au cycle actuel de développement, vous allez vouloir un chroot gutsy. Quelquefois, il se peut que la version en développement ne soit pas installable directement. Dans ce cas, il vous faut d'abord installer la dernière version stable, puis mettre à niveau vers la version en développement.

C'est le cas (actuellement pour Gutsy Gibbon). Voici donc la procédure :

  • Créez un pbuilder Feisty : sudo pbuilder create
  • Changez toutes les occurrences de feisty en gutsy dans /etc/pbuilderrc
  • Mettez à jour le chroot : sudo pbuilder update --override-config
  • Utilisez l'option --override-config à chaque mise à jour (tant que la version n'est pas prise en compte par pbuilder)

Quand on travaille sur des paquets, il est souvent nécessaire de disposer de plusieurs pbuilders sur sa machine. Par exemple pour rétro-porter vers Dapper et Edgy alors que l'on développe sous Feisty, ou encore pour tester les paquets sur Debian Sid à la recherche de bogues.

Pour ce faire, le fichier /usr/share/doc/pbuilder/examples/pbuilder-distribution.sh va vous aider. Il contient par défaut :

#!/bin/sh
# script from Jamin W. Collins  BTS: #255165
# name this script 'pbuilder-woody', 'pbuilder-sid', 'pbuilder-sarge', 'pbuilder-experimental' etc.

OPERATION=$1
DISTRIBUTION=`basename $0 | cut -f2 -d '-'`
PROCEED=false
BASE_DIR="$HOME/pbuilder"
case $OPERATION in
   create|update|build|clean|login|execute )
      PROCEED=true
      ;;
esac
if ( $PROCEED == true ) then
   shift 
   sudo pbuilder $OPERATION \
      --basetgz $BASE_DIR/$DISTRIBUTION-base.tgz \
      --distribution $DISTRIBUTION \
      --buildresult $BASE_DIR/result $@
else
   echo "Invalid command..."
   echo "Valid commands are:"
   echo "   create"
   echo "   update"
   echo "   build"
   echo "   clean"
   echo "   login"
   echo "   execute"
   exit 1
fi

version améliorer avec config priver

en personnalisant la config fonctionne sur Ubuntu Debian et Fedora

voir le projet sur bitbucket

https://bitbucket.org/amidevous/fedora-rpm/src/master/pbuilder/

inclut fonction utile pour créer des multiples rapidement

#!/bin/bash
ubuntuori () {
   sudo wget "https://bitbucket.org/amidevous/fedora-rpm/raw/master/pbuilder/pbuilderrc" -O /etc/pbuilderrc
   sudo wget "https://bitbucket.org/amidevous/fedora-rpm/raw/master/pbuilder/pbuilder-ubuntu-stable" -O /usr/bin/pbuilder-$1
   chmod +x /usr/bin/pbuilder-$1
   sudo pbuilder-$1 create --override-config
}
ubuntuarc () {
   sudo wget "https://bitbucket.org/amidevous/fedora-rpm/raw/master/pbuilder/pbuilderrc" -O /etc/pbuilderrc
   sudo wget "https://bitbucket.org/amidevous/fedora-rpm/raw/master/pbuilder/pbuilder-ubuntu-old" -O /usr/bin/pbuilder-$1
   chmod +x /usr/bin/pbuilder-$1
   sudo pbuilder-$1 create --override-config
}
ubuntuarc2 () {
   sudo wget "https://bitbucket.org/amidevous/fedora-rpm/raw/master/pbuilder/pbuilderrc" -O /etc/pbuilderrc
   sudo wget "https://bitbucket.org/amidevous/fedora-rpm/raw/master/pbuilder/pbuilder-ubuntu-old2" -O /usr/bin/pbuilder-$1
   chmod +x /usr/bin/pbuilder-$1
   sudo pbuilder-$1 create --override-config
}
debianori () {
   rm -f $HOME/pbuilder/pbuilder-$1.conf
   cp $HOME/pbuilder/pbuilder-config.conf $HOME/pbuilder/pbuilder-$1.conf
   sudo rm -f /usr/bin/pbuilder-$1
   sudo cp /usr/bin/pbuilder-config /usr/bin/pbuilder-$1
   sudo chmod +x /usr/bin/pbuilder-$1
   mkdir -p $HOME/pbuilder/$1
   mkdir -p $HOME/pbuilder/$1/aptcache/
   mkdir -p $HOME/pbuilder/$1/result/
   mkdir -p $HOME/pbuilder/$1/build/
   mkdir -p $HOME/pbuilder/$1/nonexistent/
   mkdir -p $HOME/pbuilder/$1/hooks/
   sed -i 's|jammy|'$1'|g' $HOME/pbuilder/pbuilder-$1.conf
   echo 'MIRRORSITE=http://deb.debian.org/debian/' >> $HOME/pbuilder/pbuilder-$1.conf
   echo 'COMPONENTS="main contrib non-free"' >> $HOME/pbuilder/pbuilder-$1.conf
   echo 'OTHERMIRROR="deb http://deb.debian.org/debian '$1' main contrib non-free"' >> $HOME/pbuilder/pbuilder-$1.conf
   echo 'OTHERMIRROR="$OTHERMIRROR|deb-src http://deb.debian.org/debian '$1' main contrib non-free"' >> $HOME/pbuilder/pbuilder-$1.conf
   echo 'OTHERMIRROR="$OTHERMIRROR|deb http://deb.debian.org/debian-security/ '$1'-security main contrib non-free"' >> $HOME/pbuilder/pbuilder-$1.conf
   echo 'OTHERMIRROR="$OTHERMIRROR|deb-src http://deb.debian.org/debian-security/ '$1'-security main contrib non-free"' >> $HOME/pbuilder/pbuilder-$1.conf
   echo 'OTHERMIRROR="$OTHERMIRROR|deb http://deb.debian.org/debian '$1'-updates main contrib non-free"' >> $HOME/pbuilder/pbuilder-$1.conf
   echo 'OTHERMIRROR="$OTHERMIRROR|deb-src http://deb.debian.org/debian '$1'-updates main contrib non-free"' >> $HOME/pbuilder/pbuilder-$1.conf
   echo 'OTHERMIRROR="$OTHERMIRROR|deb http://deb.debian.org/debian '$1'--backports/ main contrib non-free"' >> $HOME/pbuilder/pbuilder-$1.conf
   echo 'OTHERMIRROR="$OTHERMIRROR|deb-src http://deb.debian.org/debian '$1'--backports/ main contrib non-free"' >> $HOME/pbuilder/pbuilder-$1.conf
   sudo pbuilder-$1 create --override-config
}
debianarc () {
   rm -f $HOME/pbuilder/pbuilder-$1.conf
   cp $HOME/pbuilder/pbuilder-config.conf $HOME/pbuilder/pbuilder-$1.conf
   sudo rm -f /usr/bin/pbuilder-$1
   sudo cp /usr/bin/pbuilder-config /usr/bin/pbuilder-$1
   sudo chmod +x /usr/bin/pbuilder-$1
   mkdir -p $HOME/pbuilder/$1
   mkdir -p $HOME/pbuilder/$1/aptcache/
   mkdir -p $HOME/pbuilder/$1/result/
   mkdir -p $HOME/pbuilder/$1/build/
   mkdir -p $HOME/pbuilder/$1/nonexistent/
   mkdir -p $HOME/pbuilder/$1/hooks/
   sed -i 's|jammy|'$1'|g' $HOME/pbuilder/pbuilder-$1.conf
   echo 'MIRRORSITE=http://archive.debian.org/debian/' >> $HOME/pbuilder/pbuilder-$1.conf
   echo 'COMPONENTS="main contrib non-free"' >> $HOME/pbuilder/pbuilder-$1.conf
   sudo pbuilder-$1 create --override-config
}
# Ubuntu 24.04 The Noble Numbat (le Noble numbat) support Avril 2029
sudo rm -f /usr/share/debootstrap/scripts/noble
sudo cp /usr/share/debootstrap/scripts/jammy /usr/share/debootstrap/scripts/noble
ubuntuori noble
#Ubuntu 23.10 The Mantic Minotaur (le Minotaure mantique) support Juillet 2024
sudo rm -f /usr/share/debootstrap/scripts/mantic
sudo cp /usr/share/debootstrap/scripts/jammy /usr/share/debootstrap/scripts/mantic
ubuntuori mantic
#Ubuntu 23.04 The Lunar Lobster (le Homard lunaire) support Janvier 2024
sudo rm -f /usr/share/debootstrap/scripts/lunar
sudo cp /usr/share/debootstrap/scripts/jammy /usr/share/debootstrap/scripts/lunar
ubuntuori lunar
#Ubuntu 22.10 The Kinetic Kudu (le Koudou cinétique) support 20 Juillet 2023 
sudo rm -f /usr/share/debootstrap/scripts/kinetic
sudo cp /usr/share/debootstrap/scripts/jammy /usr/share/debootstrap/scripts/kinetic
ubuntuarc kinetic
#Ubuntu 22.04 LTS The Jammy Jellyfish (la méduse chanceuse) support Avril 2027
ubuntuori jammy
#
ubuntuarc impish
#
ubuntuarc hirsute
#
ubuntuarc groovy
#
ubuntuori focal
#
ubuntuarc eoan
#
ubuntuarc disco
#
ubuntuarc cosmic
#
ubuntuori bionic
#
ubuntuarc artful
ubuntuarc zesty
ubuntuarc yakkety
ubuntuori xenial
ubuntuarc wily
ubuntuarc vivid
ubuntuarc utopic
ubuntuori trusty
ubuntuarc saucy
ubuntuarc raring
ubuntuarc quantal
ubuntuarc2 precise
ubuntuarc2 oneiric
ubuntuarc2 natty
ubuntuarc2 maverick
ubuntuarc2 lucid
ubuntuarc2 karmic
ubuntuarc2 jaunty
ubuntuarc2 intrepid
ubuntuarc2 hardy
ubuntuarc2 gutsy
ubuntuarc2 feisty
ubuntuarc2 edgy
ubuntuarc2 dapper
ubuntuarc2 breezy
debianori bookworm
debianori bullseye
debianori buster
debianarc stretch
debianarc jessie
debianarc wheezy
debianarc squeeze
debianarc lenny
debianarc etch
debianarc sarge
debianarc woody
debianarc potato
debianarc slink
debianarc hamm

Copiez ce fichier dans /usr/local/bin en remplaçant distribution par le nom de la version d'Ubuntu voulue.
Par exemple pour créer un pbuilder Dapper, vous le nommerez pbuilder-dapper :

sudo cp /usr/share/doc/pbuilder/examples/pbuilder-distribution.sh /usr/local/bin/pbuilder-dapper
Ce même script renommé en pbuilder-edgy par exemple, créerai un pbuilder edgy. En effet, le script récupère le nom de distribution que vous avez mis après le tiret dans le nom de fichier.

Répertoire de base des pbuilders

Le dossier utilisé par défaut pour les pbuilders est /var/cache/pbuilder/. Nous allons donc modifier le script et remplacer la ligne

BASE_DIR="$HOME/pbuilder"

par

BASE_DIR="/var/cache/pbuilder"

Enfin, n'oubliez pas de rendre votre script exécutable :

sudo chmod +x /usr/local/bin/pbuilder-dapper

Enfin créez le chroot du pbuilder :

sudo pbuilder-dapper create
  • pbuilder.1707715039.txt.gz
  • Dernière modification: Le 12/02/2024, 06:17
  • par 89.86.155.3