slitaz-doc-wiki-data view pages/fr/handbook/chroot.txt @ rev 4

Add pages/fr folder.
author Christopher Rogers <slaxemulator@gmail.com>
date Sat Feb 26 12:13:35 2011 +0000 (2011-02-26)
parents
children 7f77649ceb97
line source
1 ====== Environnement chrooté ======
3 Ce document décrit les étapes à réaliser pour créer un environnement chrooté afin de changer la racine du système pour travailler. Cela permet de compiler, tester et développer SliTaz sans risques pour le système hôte depuis lequel on travaille. Ce système hôte peut être SliTaz installée en dur ou tout autre système GNU/Linux tel que Debian, Fedora, PCLinuxOS, etc. On peut aussi créer un environnement chrooté en mode LiveCD associé à un média USB. Les seuls prérequis sont d'avoir une image ISO de SliTaz à disposition et un peu de temps. A noter que toutes les opérations sont réalisées en tant qu'administrateur (//root//).
5 ===== Préparer l'environnement =====
7 Pour commencer, il faut extraire le contenu de l'image ISO dans le répertoire qui va servir au chroot. Le répertoire de chroot peut se créer à l'endroit que l'on veut, nous utilisons un répertoire ///home/slitaz/chroot-env//. Pour extraire le contenu d'une image ISO, il faut la monter en //loop// sur un répertoire, pour ensuite copier le système de fichiers racine compressé (//rootfs.gz//) dans le répertoire de chroot. En supposant que l'ISO est dans le répertoire courant :
9 <code>
10 # mkdir /tmp/loop
11 # mount -o loop slitaz-3.0.iso /tmp/loop
12 # mkdir -p /home/slitaz/chroot-env
13 # cp /tmp/loop/boot/rootfs.gz \
14 /home/slitaz/chroot-env
15 # umount /tmp/loop
16 </code>
18 Maintenant qu'on a une copie du système de fichiers compressé, il faut le décompresser et le dés-archiver (c'est une archive ''cpio'' compressée avec lzma ou gzip). Pour finir cette étape de préparation et continuer, on peut retirer le //rootfs// qui n'est plus utilisé :
20 <code>
21 # cd /home/slitaz/chroot-env
22 # (zcat rootfs.gz 2>/dev/null || lzma d rootfs.gz -so) | cpio -id
23 # rm rootfs rootfs.gz
24 </code>
26 Si le dés-archivage du rootfs compressé avec LZMA échoue en utilisant la première méthode vous pouvez utiliser:
28 <code>
29 # unlzma rootfs.gz -S .gz
30 # cat rootfs | cpio -id
31 </code>
33 ===== Utiliser l'environnement =====
35 Pour utiliser l'environnement chrooté, il suffit de monter quelques systèmes de fichier virtuels et d'utiliser la commande ''chroot''. Pour se simplifier la vie on peut rapidement créer un petit script automatisant le chroot. Exemple en utilisant le répertoire de chroot ///home/slitaz/chroot-env// et en créant un script nommé //chroot_in_env.sh// dans ///home/slitaz//. A noter que le contenu du script n'a pas besoin d'être tapé mais simplement copié/coller dans le terminal et que sur un autre système que SliTaz vous pouvez dé-commenter les lignes montant/démontant ///dev// et ///tmp// :
36 <code> # cat > /home/slitaz/chroot_in_env.sh << "EOF"
38 #!/bin/sh
39 # Chroot in SliTaz to hack.
40 #
41 ROOTFS="/home/slitaz/chroot-env"
43 # Mount virtual Kernel file systems and chroot.
44 #
45 #mount --bind /dev $ROOTFS/dev
46 #mount --bind /tmp $ROOTFS/tmp
47 mount -t proc proc $ROOTFS/proc
48 mount -t sysfs sysfs $ROOTFS/sys
49 mount -t devpts devpts $ROOTFS/dev/pts
50 mount -t tmpfs shm $ROOTFS/dev/shm
52 echo "Chrooting into $ROOTFS... "
53 chroot $ROOTFS /bin/sh --login
55 # Unmount virtual Kernel file systems on exit.
56 #
57 umount $ROOTFS/dev/shm
58 umount $ROOTFS/dev/pts
59 umount $ROOTFS/sys
60 umount $ROOTFS/proc
61 #umount $ROOTFS/tmp
62 #umount $ROOTFS/dev
64 echo "Exiting $ROOTFS chroot environment... "
66 EOF
68 </code>
70 Pour finir et tester l'environnement, il suffit de rendre le script exécutable et le lancer :
72 <code>
73 # chmod +x /home/slitaz/chroot_in_env.sh
74 # sh /home/slitaz/chroot_in_env.sh
75 </code>
77 === Activer le réseau ===
79 Pour avoir le réseau afin de télécharger, naviguer en mode texte et installer des paquets de développement, il suffit de lancer le client DHCP sur la bonne interface, exemple avec //eth1// :
81 <code> # udhcpc -i eth1 </code>
83 === Installer des paquets ===
85 Si le réseau est fonctionnel, il suffit de recharger la liste des paquets et utiliser ''tazpkg get-install'' pour installer de nouveaux paquets. Si la connexion n'est pas possible, on peut télécharger les paquets du miroir depuis un autre système, les copier dans l'environnement chrooté et les installer via la commande ''tazpkg install''. Pour installer la base des outils de compilation :
87 <code> # tazpkg recharge
88 # tazpkg get-install slitaz-toolchain </code>
90 Une fois l'environnement configuré, on peut compiler des applications depuis les sources pour en créer des paquets, tester des scripts et autre. Le chapitre [[en:handbook:development|développement]] du Handbook et le [[fr:cookbook:start|Cookbook] devraient aider à aller plus loin.
92 === Sortir de l'environnement ===
94 Pour sortir de l'environnement chrooté il suffit de taper ''exit'', le script //chroot_in_env.sh// va finir son rôle en démontant le systèmes de fichiers virtuels propre au noyau Linux :
96 <code>
97 # exit
98 #
99 </code>