PbuilderHowto
Size: 3406
Comment: imported from the old wiki
|
Size: 11838
Comment: Minor update.
|
Deletions are marked like this. | Additions are marked like this. |
Line 1: | Line 1: |
= PbuilderHowto = | ||<tablestyle="float:right; font-size: 0.9em; width:40%; background:#F1F1ED; margin: 0 0 1em 1em;" style="padding:0.5em;">'''Contents'''[[BR]][[TableOfContents]]|| |
Line 5: | Line 5: |
This document describes the steps to setup a chroot for build Ubuntu packages using pbuilder. It's recommended for Ubuntu maintainers or anyone interested in building packages using HoaryHedgehog. You can build packages without pbuilder but you will need all the build dependencies of the package that you need to build installed in your running system. == Hoary chroot == Install pbuilder package. |
This document describes the steps to setup a chroot jail for building Ubuntu packages using pbuilder. It is recommended for any maintainer of Ubuntu or Debian packages, or anyone interested in building packages using Ubuntu. You can build packages without pbuilder but you must already have all the build dependencies of the package that you are building installed on your running system. If you use LVM and want to take advantage of using LVM snapshots to speed up the chroot creation/destruction, please see ["SbuildLVMHowto"] for an alternate approach. The following assume you want to install ''edgy''. If you need a ''dapper'' or ''feisty'' chroot, then exchange ''edgy'' with the appropriate distribution. == The First Steps == First install the required packages. {{{ sudo apt-get install pbuilder debootstrap devscripts }}} '''NOTE:''' devscripts is not necessary to install along with pbuilder, however if you are serious about using pbuilder and creating and maintaining packages for Ubuntu or Debian, you will want to install devscripts. Create a chroot base tarball that will contain your chroot cleanroom to build packages with. {{{ sudo pbuilder create }}} == Rebuilding a package == If everything went well, you should now have a tarball called base.tgz in your system under /var/cache/pbuilder. To check if you can download source packages, you will need an uncommented deb-src line in /etc/apt/sources.list. It should look like: {{{ deb-src http://archive.ubuntu.com/ubuntu <ubuntu_version> main restricted universe multiverse }}} Replace ''<ubuntu_version>'' with the version of ubuntu you are using (i.e. feisty, edgy, or dapper). If the line above is there but not uncommented, uncomment it. Make sure your package index files are synchronized so that apt-get knows where to find the sources. After you ensured the deb-src line is correct and uncommented, run: {{{ sudo apt-get update }}} We will build bc, a simple calculator, from source, let's download the debian source package from ubuntu repository: {{{ apt-get source bc }}} Now build the package using your chroot cleanroom you created with the command: {{{ sudo pbuilder build *.dsc }}} Once the packages are successfully built, the binary and source packages will be stored in /var/cache/pbuilder/result/ == Downloading Source Packages Using dget == There will be times when a package you want or need to build is not in the repositories of the current version of Ubuntu you are running. Rather than entering deb-src lines in your sources.list configuration for other versions of Ubuntu you are not running, you can use dget instead to download a package. dget is included in the devscripts package, hence why you should have installed it. To use dget, first locate the .dsc file of the package you are going to build. Good places to look are http://packages.ubuntu.com/ or http://packages.debian.org/ . Once you located the .dsc file. Copy the link address to it and then in a command prompt run: {{{ dget <link_address_to_foo.dsc> }}} '''NOTE:''' dget is not included in the devscripts package for Ubuntu dapper. == Signing Source Files == If you intend to upload your packages to ["REVU"], [http://mentors.debian.net/], or any other location, it is highly recommended you sign your source files (.dsc and .changes files). Both ["REVU"] and [http://mentors.debian.net/] enforce signed sources. The easiest way to do this after using pbuilder is by using ''debsign''. Assuming your packages and source files were placed in /var/cache/pbuilder/result/, run; {{{ sudo debsign /var/cache/pbuilder/result/*.changes }}} ''debsign'' is also a part of the package ''devscripts''. == Updating a chroot == It is recommended you update your chroot daily before each build, to do this task use the command below: {{{ sudo pbuilder update }}} == Speeding up build-dependency calculation == If you use feisty you can use a new build-dependency resolver based on gdebi that should be significantly faster. Change /etc/pbuilder/pbuilderrc to add this line: {{{ PBUILDERSATISFYDEPENDSCMD="/usr/lib/pbuilder/pbuilder-satisfydepends-gdebi" }}} == Universe support == If you want to rebuild a package from universe or build a new one that needs a package out of main you will need to edit /etc/pbuilderrc again, uncommenting: {{{ COMPONENTS="main restricted universe multiverse" }}} After adding the new sources you need to update the chroot, so that it picks up the new apt lines: {{{ sudo pbuilder update --override-config }}} == Building an i386 pbuilder on AMD64 == One of the things a pbuilder is useful for is building i386 packages on an AMD64 machine. You can create an i386 chroot with the command: {{{ sudo pbuilder create --debootstrapopts --arch --debootstrapopts i386 }}} == Multiple pbuilders == When you work with packages, you often want to have multple pbuilders on your machine, if for example you want to backport to Dapper while developing on the development version of Ubuntu (currently Gutsy). Or maybe you want to [https://wiki.ubuntu.com/ContributingToDebian build your packages for Debian] and have them merged back to Ubuntu. The next sections will provide some information to get you started with using multiple pbuilders using Gutsy as an example. === Update debootstrap === It is recommended to use an updated version of debootstrap from the backports repository of whatever version of Ubuntu you are using. You can either activate the backports repository in your sources.list configuration or download the source package using dget, build the packages, and install them. === Setup a pbuilder script === You can adapt the file in /usr/share/doc/pbuilder/examples/pbuilder-distribution.sh. The script needs to be modified so there's no interference with the base pbuilder setup or any other pbuilder setup you will use. The script should look like the following: {{{ #!/bin/sh # script from Jamin W. Collins BTS: #255165 # name this script 'pbuilder-gutsy', 'pbuilder-sid', 'pbuilder-dapper' etc. OPERATION=$1 DISTRIBUTION=`basename $0 | cut -f2 -d '-'` PROCEED=false BASE_DIR="/var/cache/pbuilder" case $OPERATION in create|update|build|clean|login|execute ) PROCEED=true ;; esac if [ "$PROCEED" = true ] then shift sudo /usr/sbin/pbuilder $OPERATION \ --basetgz $BASE_DIR/$DISTRIBUTION-base.tgz \ --distribution $DISTRIBUTION \ --configfile $BASE_DIR/$DISTRIBUTION/pbuilderrc \ --aptconfdir $BASE_DIR/$DISTRIBUTION/apt.config \ --buildresult $BASE_DIR/$DISTRIBUTION/result "$@" else echo "Invalid command..." echo "Valid commands are:" echo " create" echo " update" echo " build" echo " clean" echo " login" echo " execute" exit 1 fi }}} Save this script in /usr/local/bin and name it according to the distribution you want, e.g. pbuilder-gutsy. Make it executable, type in: {{{ sudo chmod +x /usr/local/bin/pbuilder-gutsy }}} Next, prepare the staging area. Do this for every distribution you want to build packages for. Again, the examples assume that the distribution you want is gutsy, change the name accordingly for other distributions. {{{ sudo mkdir /var/cache/pbuilder/gutsy sudo cp /etc/pbuilderrc /var/cache/pbuilder/gutsy/pbuilderrc }}} Then edit /var/cache/pbuilder/gutsy/pbuilderrc and make sure that the following lines refer to the correct distribution: {{{ DISTRIBUTION=gutsy BASETGZ=/var/cache/pbuilder/gutsy-base.tgz BUILDPLACE=/var/cache/pbuilder/gutsy/build/ MIRRORSITE=http://archive.ubuntu.com/ubuntu BUILDRESULT=/var/cache/pbuilder/gutsy/result/ APTCACHE="/var/cache/pbuilder/gutsy/aptcache/" }}} For '''MIRRORSITE''', it's best to use a mirror (such as {{{http://us.archive.ubuntu.com/ubuntu}}} for the US) rather than the main archive site. Also, ensure you have the correct mirror site for the distribution your building packages for. === Setup apt.config === Copy the apt configuration files from your system to /var/cache/pbuilder/gutsy/apt.config {{{ sudo cp -R /etc/apt /var/cache/pbuilder/gutsy/apt.config }}} '''NOTE:''' If you are going to use pbuilder to build packages for Debian, it is recommended you configure the apt keys for Debian under your system's apt configuration first before copying the contents of your system's apt directory to /var/cache/pbuilder/<Debian-version>/apt.config. Next, edit /var/cache/pbuilder/feisty/apt.config/sources.list according to the distro you'll be building packages for. For Gutsy, it should be no more than one line. {{{ deb http://us.archive.ubuntu.com/ubuntu/ gutsy main restricted universe multiverse }}} === Create the chroot cleanroom === Finally run {{{sudo pbuilder-gutsy create}}} to create the pbuilder chroot cleanroom (gutsy-base.tgz). Follow the same steps to create pbuilder chroots for other distributions (e.g. pbuilder-edgy, pbuilder-dapper, pbuilder-sid, etc.). == Installing Pbuilder on Warty, Hoary or Breezy == Install pbuilder package and debootstrap. |
Line 17: | Line 216: |
DISTRIBUTION=hoary }}} |
DISTRIBUTION=edgy }}} |
Line 21: | Line 221: |
edit your /etc/pbuilder/pbuilderrc: | Edit your /etc/pbuilder/pbuilderrc: |
Line 26: | Line 226: |
now you'll copy needed files of /etc/apt to it and {{{ sudo mkdir /etc/pbuilder/apt.config/ sudo cp -ar /etc/apt/* /etc/pbuilder/apt.config/ sudo touch /etc/pbuilder/apt.config/apt.conf.d/allow-unauthenticated |
Now you'll copy needed files of /etc/apt to it and {{{ sudo -s mkdir /etc/pbuilder/apt.config/ cp -ar /etc/apt/* /etc/pbuilder/apt.config/ echo "APT::Get::AllowUnauthenticated 1;" >> /etc/pbuilder/apt.config/apt.conf.d/allow-unauthenticated exit |
Line 33: | Line 235: |
and add the following line to /etc/pbuilder/apt.config/apt.conf.d/allow-unauthenticated {{{ ! APT::Get::AllowUnauthenticated 1; }}} |
|
Line 39: | Line 237: |
break future updates to your pbuilder chroot, as update-notifier wont normally be installed. Save the file and run the command below to build your hoary chroot: {{{ sudo pbuilder create --distribution hoary }}} == Rebuilding a package == If you reach this point you're now with a Hoary chroot ready to build a package. We will get a Debian source package from Ubuntu repository to test it. Check if you can download source packages, you will need a uncommented deb-src line at /etc/apt/sources.list, containing: {{{ deb-src http://archive.ubuntu.com/ubuntu hoary main restricted }}} If the line above is there but not uncommented, uncomment it and run 'sudo apt-get update'. We will build bc, a simple calculator, from source, let's download the debian source package from ubuntu repository: {{{ sudo apt-get source bc }}} You can build the package using your Hoary chroot with the command: {{{ sudo pbuilder build *.dsc }}} In the end, the binary and source package will be at /var/cache/pbuilder/result/ == Updating Hoary chroot == I recommend you update your chroot before each build, to this task use the comand below: {{{ sudo pbuilder update }}} == Universe support == If you want to rebuild a package from universe or build a new one that needs a package out of main you will need to edit /etc/pbuilderrc again, changing: {{{ OTHERMIRROR="deb http://archive.ubuntu.com/ubuntu hoary universe" }}} Now you need to update your chroot with the new configuration: {{{ sudo pbuilder update --distribution hoary --override-config }}} == Upgrading to Breezy == If you want to participate in the current release cycle, you will want to have a BreezyBadger chroot. * change all occurences of {{{hoary}}} in /etc/pbuilderrc and /etc/pbuilderrc/apt.config/ to {{{breezy}}} * {{{ sudo pbuilder update --override-config }}} |
break future updates to your pbuilder chroot, as update-notifier won't normally be installed. Save the file and run the command below to build your Edgy chroot: {{{ sudo pbuilder create --distribution edgy }}} == Running a Shell When Build Fails (Intro to Hook Scripts) == This is done using a ''hook'' script. First we need to create a directory to home your pbuilder hooks. This can be anywhere but we'll use a directory called .pbuilder-hooks in your home directory for this example: {{{ mkdir ~/.pbuilder-hooks }}} Now we need to tell pbuilder to use this directory as its hooks directory. Edit ~/.pbuilderrc and add the following line, replacing <username> with your username: {{{ HOOKDIR=/home/<username>/.pbuilder-hooks }}} Then we need to add a hook script to be called by pbuilder when the build fails. The script needs to be placed in the HOOKDIR and made executable. The name of the hook script is also important. See the pbuilder man page for details. As you can see, for this example, we need to name the script C<digit><digit><whatever-else-you-want> so let's call it C10shell. Edit the new file ~/.pbuilder-hooks/C10shell and add the following: {{{ #!/bin/bash # invoke shell if build fails. /bin/bash < /dev/tty > /dev/tty }}} This script must be made world executable for pbuilder to execute it, so now we run: {{{ chmod a+x ~/.pbuilder-hooks/C10shell }}} And you're all set. |
Line 110: | Line 270: |
------ ["CategoryMOTU"] |
ContentsBRTableOfContents |
Introduction
This document describes the steps to setup a chroot jail for building Ubuntu packages using pbuilder. It is recommended for any maintainer of Ubuntu or Debian packages, or anyone interested in building packages using Ubuntu.
You can build packages without pbuilder but you must already have all the build dependencies of the package that you are building installed on your running system.
If you use LVM and want to take advantage of using LVM snapshots to speed up the chroot creation/destruction, please see ["SbuildLVMHowto"] for an alternate approach.
The following assume you want to install edgy. If you need a dapper or feisty chroot, then exchange edgy with the appropriate distribution.
The First Steps
First install the required packages.
sudo apt-get install pbuilder debootstrap devscripts
NOTE: devscripts is not necessary to install along with pbuilder, however if you are serious about using pbuilder and creating and maintaining packages for Ubuntu or Debian, you will want to install devscripts.
Create a chroot base tarball that will contain your chroot cleanroom to build packages with.
sudo pbuilder create
Rebuilding a package
If everything went well, you should now have a tarball called base.tgz in your system under /var/cache/pbuilder.
To check if you can download source packages, you will need an uncommented deb-src line in /etc/apt/sources.list. It should look like:
deb-src http://archive.ubuntu.com/ubuntu <ubuntu_version> main restricted universe multiverse
Replace <ubuntu_version> with the version of ubuntu you are using (i.e. feisty, edgy, or dapper). If the line above is there but not uncommented, uncomment it. Make sure your package index files are synchronized so that apt-get knows where to find the sources.
After you ensured the deb-src line is correct and uncommented, run:
sudo apt-get update
We will build bc, a simple calculator, from source, let's download the debian source package from ubuntu repository:
apt-get source bc
Now build the package using your chroot cleanroom you created with the command:
sudo pbuilder build *.dsc
Once the packages are successfully built, the binary and source packages will be stored in /var/cache/pbuilder/result/
Downloading Source Packages Using dget
There will be times when a package you want or need to build is not in the repositories of the current version of Ubuntu you are running. Rather than entering deb-src lines in your sources.list configuration for other versions of Ubuntu you are not running, you can use dget instead to download a package. dget is included in the devscripts package, hence why you should have installed it.
To use dget, first locate the .dsc file of the package you are going to build. Good places to look are http://packages.ubuntu.com/ or http://packages.debian.org/ . Once you located the .dsc file. Copy the link address to it and then in a command prompt run:
dget <link_address_to_foo.dsc>
NOTE: dget is not included in the devscripts package for Ubuntu dapper.
Signing Source Files
If you intend to upload your packages to ["REVU"], [http://mentors.debian.net/], or any other location, it is highly recommended you sign your source files (.dsc and .changes files). Both ["REVU"] and [http://mentors.debian.net/] enforce signed sources. The easiest way to do this after using pbuilder is by using debsign. Assuming your packages and source files were placed in /var/cache/pbuilder/result/, run;
sudo debsign /var/cache/pbuilder/result/*.changes
debsign is also a part of the package devscripts.
Updating a chroot
It is recommended you update your chroot daily before each build, to do this task use the command below:
sudo pbuilder update
Speeding up build-dependency calculation
If you use feisty you can use a new build-dependency resolver based on gdebi that should be significantly faster. Change /etc/pbuilder/pbuilderrc to add this line:
PBUILDERSATISFYDEPENDSCMD="/usr/lib/pbuilder/pbuilder-satisfydepends-gdebi"
Universe support
If you want to rebuild a package from universe or build a new one that needs a package out of main you will need to edit /etc/pbuilderrc again, uncommenting:
COMPONENTS="main restricted universe multiverse"
After adding the new sources you need to update the chroot, so that it picks up the new apt lines:
sudo pbuilder update --override-config
Building an i386 pbuilder on AMD64
One of the things a pbuilder is useful for is building i386 packages on an AMD64 machine. You can create an i386 chroot with the command:
sudo pbuilder create --debootstrapopts --arch --debootstrapopts i386
Multiple pbuilders
When you work with packages, you often want to have multple pbuilders on your machine, if for example you want to backport to Dapper while developing on the development version of Ubuntu (currently Gutsy). Or maybe you want to [https://wiki.ubuntu.com/ContributingToDebian build your packages for Debian] and have them merged back to Ubuntu. The next sections will provide some information to get you started with using multiple pbuilders using Gutsy as an example.
Update debootstrap
It is recommended to use an updated version of debootstrap from the backports repository of whatever version of Ubuntu you are using. You can either activate the backports repository in your sources.list configuration or download the source package using dget, build the packages, and install them.
Setup a pbuilder script
You can adapt the file in /usr/share/doc/pbuilder/examples/pbuilder-distribution.sh. The script needs to be modified so there's no interference with the base pbuilder setup or any other pbuilder setup you will use. The script should look like the following:
# script from Jamin W. Collins BTS: #255165 # name this script 'pbuilder-gutsy', 'pbuilder-sid', 'pbuilder-dapper' etc. OPERATION=$1 DISTRIBUTION=`basename $0 | cut -f2 -d '-'` PROCEED=false BASE_DIR="/var/cache/pbuilder" case $OPERATION in create|update|build|clean|login|execute ) PROCEED=true ;; esac if [ "$PROCEED" = true ] then shift sudo /usr/sbin/pbuilder $OPERATION \ --basetgz $BASE_DIR/$DISTRIBUTION-base.tgz \ --distribution $DISTRIBUTION \ --configfile $BASE_DIR/$DISTRIBUTION/pbuilderrc \ --aptconfdir $BASE_DIR/$DISTRIBUTION/apt.config \ --buildresult $BASE_DIR/$DISTRIBUTION/result "$@" else echo "Invalid command..." echo "Valid commands are:" echo " create" echo " update" echo " build" echo " clean" echo " login" echo " execute" exit 1 fi
Save this script in /usr/local/bin and name it according to the distribution you want, e.g. pbuilder-gutsy. Make it executable, type in:
sudo chmod +x /usr/local/bin/pbuilder-gutsy
Next, prepare the staging area. Do this for every distribution you want to build packages for. Again, the examples assume that the distribution you want is gutsy, change the name accordingly for other distributions.
sudo mkdir /var/cache/pbuilder/gutsy sudo cp /etc/pbuilderrc /var/cache/pbuilder/gutsy/pbuilderrc
Then edit /var/cache/pbuilder/gutsy/pbuilderrc and make sure that the following lines refer to the correct distribution:
DISTRIBUTION=gutsy BASETGZ=/var/cache/pbuilder/gutsy-base.tgz BUILDPLACE=/var/cache/pbuilder/gutsy/build/ MIRRORSITE=http://archive.ubuntu.com/ubuntu BUILDRESULT=/var/cache/pbuilder/gutsy/result/ APTCACHE="/var/cache/pbuilder/gutsy/aptcache/"
For MIRRORSITE, it's best to use a mirror (such as http://us.archive.ubuntu.com/ubuntu for the US) rather than the main archive site. Also, ensure you have the correct mirror site for the distribution your building packages for.
Setup apt.config
Copy the apt configuration files from your system to /var/cache/pbuilder/gutsy/apt.config
sudo cp -R /etc/apt /var/cache/pbuilder/gutsy/apt.config
NOTE: If you are going to use pbuilder to build packages for Debian, it is recommended you configure the apt keys for Debian under your system's apt configuration first before copying the contents of your system's apt directory to /var/cache/pbuilder/<Debian-version>/apt.config.
Next, edit /var/cache/pbuilder/feisty/apt.config/sources.list according to the distro you'll be building packages for. For Gutsy, it should be no more than one line.
deb http://us.archive.ubuntu.com/ubuntu/ gutsy main restricted universe multiverse
Create the chroot cleanroom
Finally run sudo pbuilder-gutsy create to create the pbuilder chroot cleanroom (gutsy-base.tgz).
Follow the same steps to create pbuilder chroots for other distributions (e.g. pbuilder-edgy, pbuilder-dapper, pbuilder-sid, etc.).
Installing Pbuilder on Warty, Hoary or Breezy
Install pbuilder package and debootstrap.
Edit /etc/pbuilder/pbuilderrc changing the following directives:
MIRRORSITE=http://archive.ubuntu.com/ubuntu DISTRIBUTION=edgy
Since pbuilder will complain about unauthenticated packages, you have to allow unauthenticated packages. You can make it like so:
Edit your /etc/pbuilder/pbuilderrc:
APTCONFDIR="/etc/pbuilder/apt.config/"
Now you'll copy needed files of /etc/apt to it and
sudo -s mkdir /etc/pbuilder/apt.config/ cp -ar /etc/apt/* /etc/pbuilder/apt.config/ echo "APT::Get::AllowUnauthenticated 1;" >> /etc/pbuilder/apt.config/apt.conf.d/allow-unauthenticated exit
NOTE: Make sure to remove 99update-notifier from /etc/pbuilder/apt.config/apt.conf.d/ if you have copied it in the last step. It can potentially break future updates to your pbuilder chroot, as update-notifier won't normally be installed.
Save the file and run the command below to build your Edgy chroot:
sudo pbuilder create --distribution edgy
Running a Shell When Build Fails (Intro to Hook Scripts)
This is done using a hook script. First we need to create a directory to home your pbuilder hooks. This can be anywhere but we'll use a directory called .pbuilder-hooks in your home directory for this example:
mkdir ~/.pbuilder-hooks
Now we need to tell pbuilder to use this directory as its hooks directory. Edit ~/.pbuilderrc and add the following line, replacing <username> with your username:
HOOKDIR=/home/<username>/.pbuilder-hooks
Then we need to add a hook script to be called by pbuilder when the build fails. The script needs to be placed in the HOOKDIR and made executable. The name of the hook script is also important. See the pbuilder man page for details. As you can see, for this example, we need to name the script C<digit><digit><whatever-else-you-want> so let's call it C10shell. Edit the new file ~/.pbuilder-hooks/C10shell and add the following:
# invoke shell if build fails. /bin/bash < /dev/tty > /dev/tty
This script must be made world executable for pbuilder to execute it, so now we run:
chmod a+x ~/.pbuilder-hooks/C10shell
And you're all set.
See also
pbuilder User's Manual: http://www.netfort.gr.jp/~dancer/software/pbuilder-doc/pbuilder-doc.html
["CategoryMOTU"]
PbuilderHowto (last edited 2020-01-28 13:36:36 by paelzer)