Chroot : changement de dossier racine
La commande chroot permet de changer le répertoire racine vers un nouvel emplacement.
Cette opération peut être utilisée dans divers cas :
- prison : empêche un utilisateur ou un programme de remonter dans l'arborescence et le cantonne à une nouvelle arborescence restreinte.
- changement d'environnement : permet de basculer vers un autre système linux (autre architecture, autre distribution, autre version). Nous détaillerons ici cette technique.
Utilisation
Changer de système
Cette technique est le plus souvent utilisée pour récupérer une installation endommagée.
Ici le chroot sera utilisé après le démarrage sur un système sain pour se retrouver dans l'environnement endommagé et faire des modifications directement dans ce dernier environnement.
Astuce : Vous pouvez taper
sudo -i
avant de faire les opérations suivantes pour devenir "root" et ne pas devoir entrer "sudo".
- Démarrez sur un système sain. Par exemple : un live CD
- Montez la partition racine du système endommagé :
sudo mkdir /media/system sudo mount </dev/partition> /media/system
par exemple, si sda2 est la partition racine, la commande sera : "sudo mount /dev/sda2 /media/system"
- Préparez les dossiers spéciaux /proc et /dev :
sudo mount --bind /dev /media/system/dev sudo mount -t proc /proc /media/system/proc
- Dans certains cas (réparation de Grub avec update-grub par exemple) vous devrez lier le /run :
sudo mount --bind /run /media/system/run
Note : Vous pourriez aussi avoir besoin de monter /sys :
sudo mount -t sysfs /sys /media/system/sys
- Pour démarrer la connexion internet:
net-setup eth0
- Copiez le /etc/resolv.conf pour la connexion internet (à faire seulement si votre connexion internet ne marche pas directement sans rien faire dans l'environnement chrooté) :
sudo cp /etc/resolv.conf /media/system/etc/resolv.conf
- Changez d'environnement :
sudo chroot /media/system
- En cas d'erreur à propos de "/bin/zsh" remplacer cette commande par
sudo chroot /media/system /bin/bash
.
Maintenant vous êtes sur l'installation endommagée et vous pouvez travailler dessus pour y corriger les problèmes.
Pour quitter l'environnement, il suffit d'un :
exit
Pour démonter la partition racine du système endommagé :
sudo umount /media/system/dev sudo umount /media/system/proc sudo umount /media/system/sys sudo umount /media/system/run sudo umount /media/system
Exemple pratique avec une version 17.10 et 18.04 ainsi qu'en version 20.04
Le plus souvent, cette utilisation est faite à partir d'une clé USB d'installation de ubuntu. Ceci est un cas pratique fait en EFI sur partition système non chiffrée. Les commandes de préparation sont
setxkbmap fr ### afin d'avoir un clavier français. sudo -i ### afin d'éviter de passer son temps à frapper cette commande
L'identification de la partition système à cibler sera plus aisée en frappant la commande
fdisk -l
Le montage de la partition système à cibler se fera en frappant la commande (pensez à remplacer XXXX par la bonne valeur).
mount /dev/XXXX /mnt
Le montage des répertoires se fera avec ces commandes (copier/coller).
mount -t proc /proc /mnt/proc mount -t sysfs /sys /mnt/sys mount --bind /dev /mnt/dev mount --bind /run /mnt/run mount --bind /sys /mnt/sys mount --bind /etc/resolv.conf /mnt/etc/resolv.conf modprobe efivars
Le changement d'environnement se fera avec cette commande
chroot /mnt
Quelques contrôles seront à faire par exemple
mount -t devpts devpts /dev/pts df -h && df -i ping -c4 8.8.8.8 && ping -c4 google.fr ls -ls /home
Vous pouvez alors passer à la réparation proprement dite qui a justifié cette opération. Espérons simplement que ce message d'erreur "Running in chroot, ignoring request." n'empêchera pas votre réparation. Lorsque cela sera fini, le plus simple est de rebooter pour vérifier. La commande suivante s'occupe de toutes les déconnexions.
reboot
Pour un ubuntu installé dans une partition BTRFS
Utiliser un environnement 32 bits sur une installation 64 bits
Cette option devient de plus en plus désuète puisque la plupart des machines sont maintenant en 64 bits.
Préférez toujours utiliser 'chroot' entre deux systèmes de même architecture.
CD Live 32bit pour une installation système 32bits et de même pour 64bits.
Sinon, voir le tutoriel chroot32bits
Convertir un environnement 32 bits en environnement 64 bits
Il faut d'abord faire la fonctionnalité "chroot" telle que décrite ci-dessus.
Il est préférable de mettre à jour le logiciel de façon classique.
apt update && apt upgrade
Puis de procéder à l'installation des modules 64 bits absents avec ces commandes:
dpkg --add-architecture amd64 apt-get update apt-get install linux-image-amd64:amd64