retour vers Linux
http://www.linux-mag.com/id/7897/
je lance parted sur mon périphérique disque, et je fais un "mklabel gpt" sur mon disque pour créer une table de partition de type gpt.
$ sudo parted /dev/mapper/isw_cfdcahfeac_DONNEES > mklabel gpt
puis "mkpart primary 0 -1" pour faire une partition primaire commençant a 0 et se terminant a -1 ( le max du disque )
> mkpart primary 0 -1
je lui donne un nom par name suivi du numero de partition et le nom souhaité
> name 1 DONNEES1
et j'affiche la table des partitions du disque par print
> print Numéro Début Fin Taille Système de fichiers Nom Fanions 1 17,4kB 3001GB 3001GB ext3 DONNEES1 raid > quitje quitte parted et je fait la création du FS par ( attention de choisir un type de FS qui supporte l'espace a formater )
$ sudo mkfs.ext3 /dev/mapper/isw_cfdcahfeac_DONNEES1
Si vous avez une carte mère compatible EFI et donc GPT, il existe 2 options du noyaux pour les utiliser:
File Systems Partition Types [*] Advanced partition selection [*] EFI GUID Partition support (NEW)
ces 2 options permettent, après compilation, le support natif des partitions GPT sans utiliser kpartx. Je n'ai pas encore pu tester car je n'ai pas de bios EFI.Voir sur wikipedia: table de parition GUID, en anglais :-(
pour cela utilisons l'utilitaire kpartx (fait partie des multipathtools) qui permet de mapper de très nombreux types de partitions.
sudo kpartx -l /dev/mapper/isw_cfdcahfeac_DONNEESla commande ci-dessus, permet de lister les partitions détectées.
sudo kpartx -a /dev/mapper/isw_cfdcahfeac_DONNEESpermet de détecter les partitions et de construire le fichier périphérique correspondant /dev/mapper/isw_cfdcahfeac_DONNEES1 dans mon cas de raid5 intel semi-matériel.
Vous pouvez maintenant accéder au périphérique comme vous le faite pour les autres patitions, avec un mount ou en ajoutant son UUID ( tune2fs -l /dev/nom_periherique | grep UUID , ou la commande sudo blkid -g avant un sudo blkid, ou encore ls -l /dev/disk/by-uuid/) au fichier fstab pour qu'il soit monté au démarrage, après l'initramfs. Attention a ne pas se tromper en prenant l'UUID du disque au lieu de celui de la partition :-) . Monter la patition a partir de fstab ne vous permettra pas de booter sur votre partion GPT. Pour booter sur cette partition vous devez configurer initramfs pour l'acces durant le boot et grub pour le boot lui-même.
Sous kubuntu 12.04 cette partie n'est plus nécessaire. Ceci grâce a un nouveau pakage: kpartx-boot qui s'ajoute a kpartx et va aller s'installer dans l'initramfs et le systeme.
Afin de détecter ma partition GPT de plus de 2To dès que possible au boot, je suis passé par l'initramfs. Si vous installez la totalité des outils multipathtools, pas de problème, kpartx et les autres outils seront intégrés a l'initramfs. Par contre lorsque l'on installe kpartx sans les multipathtools celui-ci n'est pas installé dans initramfs.Pour l'installer seul dans l'initramfs,j'ai ajouté 2 fichiers:
#!/bin/sh #Ajout de kaprtx a /sbin pour la detection et le montage de partition sup a 2To PREREQS="" prereqs() { echo "$PREREQ" } case $1 in # get pre-requisites prereqs) prereqs exit 0 ;; esac . /usr/share/initramfs-tools/hook-functions copy_exec /sbin/kpartx sbin
Cela ajoute kpartx ( l'exécutable pas le script... hein.. tout le monde suit ? ) à /sbin qui sera copié dans l'initramfs lors de la mise a jours ou la creation d'initramfs.
#!/bin/sh # script d'exécution de kpartx après dmraid pour la détection de partition sup a 2To PREREQS="dmraid" prereqs() { echo $PREREQS } case $1 in # get pre-requisites prereqs) prereqs exit 0 ;; esac kpartx -a /dev/mapper/isw_*
UNIQUEMENT si vous avez un raid par dmraid sur Kubuntu 10.4 ( lucid): une temporisation est nécessaire pour attendre la bonne execution de dmraid du fait de l'optimisation du boot et de la mise en parallèles d'élément du boot. Le fichier /usr/share/initramfs-tools/scripts/local-top/kpartx devient ( j'ai rajouté une boucle pour détecter toutes les secondes la disponibilité du raid ):
#!/bin/sh # script d'exécution de kpartx après dmraid pour la detection de partition sup a 2To PREREQS="dmraid" prereqs() { echo $PREREQS } case $1 in # get pre-requisites prereqs) prereqs exit 0 ;; esac tempo=0 while [ ! -b /dev/mapper/isw_* ] && [ $tempo -le 60 ] do sleep 1 tempo=`expr $tempo + 1` echo "activation partition GPT en cours, attente disponibilité $tempo" done sleep 2 /sbin/kpartx -a /dev/mapper/isw_*
ne pas oublier de mettre les droit 755 avec le proprietaire root sur les 2 fichiers et de faire un
sudo update-initramfs -u
après avoir fait une copie de sauvegarde de votre /boot/initrd.img* de démarrage
Pour ma part mon bios n'autorise pas le boot sur mon raid quelque soit le type de table de partition.
J'ai donc un SSD pour le système, en MBR. Le SSD accélère notablement le système en plus de simplifier le boot
N'ayant pas rencontré ce problème de GRUB sur GPT je vous laisse googleliser grub gpt.
Il existe de multiples solutions: une fausse table de partion mbr, une mini partition mbr pour grub2 en début de disque, ...
http://www.wensley.org.uk/gpt
http://wiki.archlinux.org/index.php/GUID_Partition_Table
http://www.linuxmint-fr.org/forum/33-trucs-et-astuces/72838-resolu-probleme-grub2-et-gpt.html
N'hesitez pas a me faire vos retours sur cette partie ou sur d'autres d'ailleurs.Mon mail dans À_propos