User Tools

Site Tools


informatique:linux:raid0_sous_linux

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
Next revisionBoth sides next revision
informatique:linux:raid0_sous_linux [2011/02/13 21:54] – ajout raid5 pteuinformatique:linux:raid0_sous_linux [2012/11/03 00:01] – modification externe 127.0.0.1
Line 120: Line 120:
  
 =====Divers===== =====Divers=====
 +
 +====Créer un volume RAID1 avec un seul disque====
 +Il s'agit ici de créer un RAID 1 avec un seul disque, donc un RAID en défaut (pas de réplication de données mais la machine fonctionne toujours). Cela permet par exemple de préparer une machine avec un seul disque en attendant la livraison du second.
 +
 +<code>
 +mdadm --create /dev/md0 --level=1 --raid-devices=2 /dev/sda1 missing
 +</code>
 +
 +-> On créer /dev/md0 en RAID1 en utilisant 2 partitions : /dev/sda1 et une qui manque en temps normal c'est plus utile d'utiliser une 2nde partition
 +
 +
 +=====Création d'un raid5 + LVM=====
 +
 +====Volume RAID 5====
 +
 +Un raid0 avec de la redondance pour la sécurité des données ? C'est un raid5 et c'est ce que je vais tenté ("tenter" car c'est un raid software avec un processeur [[http://fr.wikipedia.org/wiki/Intel_Atom#Pineview|atom n550]], et c'est un processeur un peu léger pour du calcul de parité).
 +
 +Première chose : repérer les noms des disques :
 +<code bash>
 +sudo fdisk -l | grep Disk
 +Disk /dev/sda: 64.0 GB, 64023257088 bytes
 +Disk /dev/sdb: 2000.4 GB, 2000398934016 bytes
 +Disk /dev/sdc: 2000.4 GB, 2000398934016 bytes
 +Disk /dev/sdd: 2000.4 GB, 2000398934016 bytes
 +</code>
 +Dans mon cas je vais utiliser /dev/sdb, /dev/sdc et /dev/sdd pour mon RAID 5.
 +
 +Puis, créer des partitions de type "Raid auto detect" (code : FD) et de même taille sur tous les disques. Je vous conseille d'utiliser cfdisk plutôt que fdisk car dans mon cas, j'obtenais ce message d'erreur en créant mon volume RAID (pourtant les modifications étaient bien écritent (w) sur les disques) :
 +<code bash>
 +mdadm --create --verbose /dev/md0 --level=5 --raid-devices=3 --assume-clean /dev/sd[bdd]1
 +mdadm: layout defaults to left-symmetric
 +mdadm: layout defaults to left-symmetric
 +mdadm: chunk size defaults to 512K
 +mdadm: cannot open /dev/sdc1: No such file or directory
 +</code>
 +
 +Après les avoir créés avec cfdisk, j'obtient encore une erreur !
 +<code bash>
 +mdadm --create --verbose /dev/md0 --level 5 --assume-clean --raid-devices=3 /dev/sdb1 /dev/sdc1 /dev/sdd1
 +mdadm: layout defaults to left-symmetric
 +mdadm: layout defaults to left-symmetric
 +mdadm: chunk size defaults to 512K
 +mdadm: super1.x cannot open /dev/sdc1: Device or resource busy
 +mdadm: /dev/sdc1 is not suitable for this array.
 +mdadm: super1.x cannot open /dev/sdd1: Device or resource busy
 +mdadm: /dev/sdd1 is not suitable for this array.
 +mdadm: create aborted
 +</code>
 +
 +D'après http://www.righteoushack.net/?p=197 il pourrait s'agir d'un reliquat de bug lié aux drivers d'un fake-raid (configuré dans le BIOS) ; je teste :
 +<code bash>
 +sudo aptitude remove dmraid
 +</code>
 +
 +... mais toujours le même problème :(
 +
 +N'ayant rien à perdre je décide de passer la prise en charge des disques SATA dans le BIOS en "AHCI" plutôt que "IDE enhanced" comme auparavent. Normalement les disques SATA doivent toujours être configurés en AHCI car cela permet la prise en charge du NCQ et autres, mais il me semble que lorsqu'on créer un RAID software cela est générateur de problème. Mais au point où j'en suis..
 +
 +Au reboot, les disques ont été renumérotés :
 +<code bash>
 +sudo fdisk -l | grep Disk
 +Disk /dev/sda: 2000.4 GB, 2000398934016 bytes
 +Disk /dev/sdb: 2000.4 GB, 2000398934016 bytes
 +Disk /dev/sdc: 64.0 GB, 64023257088 bytes
 +Disk /dev/sdd: 2000.4 GB, 2000398934016 bytes
 +</code>
 +
 +<code bash>
 +# Création du raid 5 avec 3 partitions : /dev/sda1 /dev/sdb1 /dev/sdd1
 +# --assume-clean permet d'éviter le calcul de parité à la création
 +mdadm --create --verbose /dev/md0 --level 5 --assume-clean --raid-devices=3 /dev/sd[abd]1
 +mdadm: layout defaults to left-symmetric
 +mdadm: layout defaults to left-symmetric
 +mdadm: chunk size defaults to 512K
 +mdadm: /dev/sdb1 appears to be part of a raid array:
 +    level=raid5 devices=3 ctime=Thu Sep  6 23:40:51 2012
 +mdadm: size set to 1953381888K
 +Continue creating array? y
 +mdadm: Defaulting to version 1.2 metadata
 +mdadm: array /dev/md0 started.
 +</code>
 +
 +Rofl ! It works !
 +
 +Il faut attendre un peu le temps de la construction du raid, puis on vérifie :
 +<code bash>
 + sudo mdadm --detail /dev/md0
 +/dev/md0:
 +        Version : 1.2
 +  Creation Time : Wed Sep 12 21:35:52 2012
 +     Raid Level : raid5
 +     Array Size : 3906763776 (3725.78 GiB 4000.53 GB)
 +  Used Dev Size : 1953381888 (1862.89 GiB 2000.26 GB)
 +   Raid Devices : 3
 +  Total Devices : 3
 +    Persistence : Superblock is persistent
 +
 +    Update Time : Thu Sep 13 18:00:13 2012
 +          State : clean
 + Active Devices : 3
 +Working Devices : 3
 + Failed Devices : 0
 +  Spare Devices : 0
 +
 +         Layout : left-symmetric
 +     Chunk Size : 512K
 +
 +           Name : ymir2: (local to host ymir2)
 +           UUID : 5766333b:7721932e:a40ebe2e:0c6fe1d0
 +         Events : 2
 +
 +    Number   Major   Minor   RaidDevice State
 +                    1        0      active sync   /dev/sda1
 +                   17        1      active sync   /dev/sdb1
 +                   49        2      active sync   /dev/sdd1
 +
 +
 +# ou :
 +cat /proc/mdstat
 +Personalities : [raid6] [raid5] [raid4] [linear] [multipath] [raid0] [raid1] [raid10]
 +md0 : active raid5 sdd1[2] sdb1[1] sda1[0]
 +      3906763776 blocks super 1.2 level 5, 512k chunk, algorithm 2 [3/3] [UUU]
 +
 +unused devices: <none>
 +</code>
 +
 +----
 +
 +Dans le première commande on pourrait tilter sur la ligne :
 +<code bash>
 +     Array Size : 3907020800 (3726.03 GiB 4000.79 GB)
 +</code>
 +3726.03 GiB alors que je devrait avoir 4 To ? WTF !!
 +
 +Juste un rappel pour vérifier tout ça :
 +  * 8 bits = 1 octet (byte en anglais : un octet et one byte c'est pareil !). Les abréviations respectives sont b (bit), o (octet) et B (byte).
 +  * 1 kB = 1 ko = 1000 octets (bytes). Dans la même logique, 1 MB vaut 1000 kB, 1 GB vaut 1000 MB, etc... : **ce sont des puissances de 10** : 1000 c'est 10^3.
 +  * 1 KiB vaut, lui, 1024 octets (bytes). Dans la même logique, 1 KiB = 1024 B, 1 MiB vaut 1024 KiB, 1 GiB vaut 1024 MiB, etc... **ce sont des puissances de 2** (normal pour de l'informatique) : 1024 c'est 2^10.
 +
 +<note>
 +Les //X//i se prononcent kibi (Ki), mébi (Mi), etc...
 +</note>
 +
 +<note>
 +Les abréviations des kilos sont "k" pour les puissances de 10 et "Ki" pour les puissances de 2. C'est exprès, pour qu'on confonde.
 +</note>
 +
 +Autant la première notation (B, kB, MB...) est assez classique et facile à calculer :
 +<code>
 +1 GB = 10^3 MB = 10^6 kB = 10^9 B = 1 000 000 000 bytes
 +</code>
 +... autant la seconde n'est pas naturelle (pour les hommes en tout cas) :
 +<code>
 +1 GiB = 2^10 MiB = 2^20 KiB = 2^30 B soit 1 073 741 824 bytes
 +</code>
 +Ce qui nous amène à la conclusion : 1 GiB "vaut plus" que 1GB. (c'est pour ça que les vendeurs de disques dur comptent en GB, ça gonfle les capacités :) ). Mais les ordinateurs, eux, comptent en puissance de 2, en //X//iB (kilo, méga, giga, etc...). Donc un disque dur de 1 To (1 TB) acheté dans le commerce ne fait que : ''10^12 / 2^40 = 0.909 TiB''
 +
 +Voici la table de conversion entre //X//B et //X//iB :
 +<code>
 +1 TB = 10^12 o => 0.909 TiB
 +1 GB = 10^9  o => 0.931 GiB
 +1 MB = 10^6  o => 0.954 MiB
 +1 KB = 10^3  o => 0.977 KiB
 +
 +1 TiB = 2^40 o => 1.100 TB
 +1 GiB = 2^30 o => 1.074 GB
 +1 MiB = 2^20 o => 1.049 MB
 +1 KiB = 2^10 o => 1.024 kB
 +</code>
 +
 +Pour finir la parenthèse, dans mon cas j'ai mon raid5 de 3 x 2 To ; ça donne 4 To de capacité utile, donc 4 x 0.909 = 3.6380 TiB (arrondi) = 3725 GiB : le compte est bon (mais pas à mon avantage).
 +
 +source : entre autres [[http://fr.wikipedia.org/wiki/Pr%C3%A9fixe_binaire|préfixe binaire]] sur Wikipédia.
 +
 +
 +----
 +
 +
 +Une fois le raid construit, si tout va bien, il faudra le monter automatiquement au démarrage la prochaine fois ; commenter la ligne "ARRAY xxx" dans le fichier ''/etc/mdadm/mdadm.conf'' et ajouter le résultat de la commande :
 +<code bash>
 +mdadm --detail --scan >> /etc/mdadm/mdadm.conf
 +
 +# PI le résultat de la commande :
 +ARRAY /dev/md0 metadata=1.2 name=ymir2:0 UUID=5766333b:7721932e:a40ebe2e:0c6fe1d0
 +</code>
 +
 +====Raid en vrac au reboot====
 +
 +Sous Ubuntu 10.10 cette fois j'ai rencontré un problème lors du reboot car il me montait /dev/md avec 2 disques et /dev/md_d0 avec le dernier. Hideux. Même en retouchant le mdadm.conf celà n'a rien changé. Je suis alors tombé sur [[http://ubuntuforums.org/showpost.php?p=7424082&postcount=11|ce post sur ubuntuforums]] qui décrit cette procédure qui a résolu mon problème : 
 +<code bash>
 +# arrêt du raid triso
 +mdadm --stop /dev/md_d0
 + mdadm: metadata format 00.90 unknown, ignored.
 + mdadm: stopped /dev/md_d0
 +
 +mdadm --auto-detect
 +
 +/usr/share/mdadm/mkconf force-generate /etc/mdadm/mdadm.conf
 +
 +update-initramfs -u
 + update-initramfs: Generating /boot/initrd.img-2.6.35-25-generic
 +
 +# puis on reboot
 +init 6
 +</code>
 +
 +Au redémarrage le volume RAID est monté correctement \o/.
 +
 +===D'autres pistes :===
 +
 +<code bash>
 +cat /proc/mdstat
 +Personalities : [linear] [multipath] [raid0] [raid1] [raid6] [raid5] [raid4] [raid10]
 +md126 : inactive sdc[1]
 +      1953514496 blocks
 +
 +md127 : active (auto-read-only) raid5 sdd[2] sdb[0]
 +      3907028992 blocks level 5, 64k chunk, algorithm 2 [3/2] [U_U]
 +
 +unused devices: <none>
 +</code>
 +
 +<code bash>
 +mdadm --examine /dev/sdb1
 +/dev/sdb1:
 +          Magic : a92b4efc
 +        Version : 0.90.00
 +           UUID : cc5892bf:a52da5c0:2ddc0efe:cce42a60 (local to host ymir2)
 +  Creation Time : Fri Aug 19 18:22:07 2011
 +     Raid Level : raid5
 +  Used Dev Size : 1953511936 (1863.01 GiB 2000.40 GB)
 +     Array Size : 3907023872 (3726.03 GiB 4000.79 GB)
 +   Raid Devices : 3
 +  Total Devices : 3
 +Preferred Minor : 0
 +
 +    Update Time : Thu Nov 17 19:32:24 2011
 +          State : clean
 + Active Devices : 3
 +Working Devices : 3
 + Failed Devices : 0
 +  Spare Devices : 0
 +       Checksum : 26f6dd32 - correct
 +         Events : 39
 +
 +         Layout : left-symmetric
 +     Chunk Size : 64K
 +
 +      Number   Major   Minor   RaidDevice State
 +this                 17        0      active sync   /dev/sdb1
 +
 +                   17        0      active sync   /dev/sdb1
 +                   33        1      active sync   /dev/sdc1
 +                   49        2      active sync   /dev/sdd1
 +
 +mdadm --examine /dev/sdc1
 +/dev/sdc1:
 +          Magic : a92b4efc
 +        Version : 0.90.00
 +           UUID : cc5892bf:a52da5c0:2ddc0efe:cce42a60 (local to host ymir2)
 +  Creation Time : Fri Aug 19 18:22:07 2011
 +     Raid Level : raid5
 +  Used Dev Size : 1953511936 (1863.01 GiB 2000.40 GB)
 +     Array Size : 3907023872 (3726.03 GiB 4000.79 GB)
 +   Raid Devices : 3
 +  Total Devices : 3
 +Preferred Minor : 0
 +
 +    Update Time : Thu Nov 17 19:32:24 2011
 +          State : clean
 + Active Devices : 3
 +Working Devices : 3
 + Failed Devices : 0
 +  Spare Devices : 0
 +       Checksum : 26f6dd44 - correct
 +         Events : 39
 +
 +         Layout : left-symmetric
 +     Chunk Size : 64K
 +
 +      Number   Major   Minor   RaidDevice State
 +this                 33        1      active sync   /dev/sdc1
 +
 +                   17        0      active sync   /dev/sdb1
 +                   33        1      active sync   /dev/sdc1
 +                   49        2      active sync   /dev/sdd1
 +
 +mdadm --examine /dev/sdd1
 +/dev/sdd1:
 +          Magic : a92b4efc
 +        Version : 0.90.00
 +           UUID : cc5892bf:a52da5c0:2ddc0efe:cce42a60 (local to host ymir2)
 +  Creation Time : Fri Aug 19 18:22:07 2011
 +     Raid Level : raid5
 +  Used Dev Size : 1953511936 (1863.01 GiB 2000.40 GB)
 +     Array Size : 3907023872 (3726.03 GiB 4000.79 GB)
 +   Raid Devices : 3
 +  Total Devices : 3
 +Preferred Minor : 0
 +
 +    Update Time : Thu Nov 17 19:32:24 2011
 +          State : clean
 + Active Devices : 3
 +Working Devices : 3
 + Failed Devices : 0
 +  Spare Devices : 0
 +       Checksum : 26f6dd56 - correct
 +         Events : 39
 +
 +         Layout : left-symmetric
 +     Chunk Size : 64K
 +
 +      Number   Major   Minor   RaidDevice State
 +this                 49        2      active sync   /dev/sdd1
 +
 +                   17        0      active sync   /dev/sdb1
 +                   33        1      active sync   /dev/sdc1
 +                   49        2      active sync   /dev/sdd1
 +</code>
 +
 +<code bash>
 +egrep -v "^$|^#" /etc/mdadm/mdadm.conf
 +DEVICE partitions
 +CREATE owner=root group=disk mode=0660 auto=yes
 +HOMEHOST <system>
 +MAILADDR root
 +ARRAY /dev/md0 level=raid5 num-devices=3 metadata=0.90 UUID=cc5892bf:a52da5c0:2ddc0efe:cce42a60
 +   devices=/dev/sdb1,/dev/sdc1,/dev/sdd1
 +</code>
 +
 +<code bash>
 +mdadm --detail --scan
 +ARRAY /dev/md/0_0 metadata=0.90 UUID=c50da923:2bb088ef:2ddc0efe:cce42a60
 +ARRAY /dev/md/0_1 metadata=0.90 UUID=cb278753:2d171315:2ddc0efe:cce42a60
 +</code>
 +
 +<code bash>
 +mdadm --stop /dev/md126
 + mdadm: stopped /dev/md126
 +mdadm --stop /dev/md127
 + mdadm: stopped /dev/md127
 +mdadm --assemble /dev/md0
 + mdadm: /dev/md0 has been started with 3 drives.
 +</code>
 +
 +<code bash>
 +mdadm --detail --scan
 +ARRAY /dev/md0 metadata=0.90 UUID=cc5892bf:a52da5c0:2ddc0efe:cce42a60
 +</code>
 +
 +<code bash>
 +cat /proc/mdstat
 +Personalities : [linear] [multipath] [raid0] [raid1] [raid6] [raid5] [raid4] [raid10]
 +md0 : active raid5 sdb1[0] sdd1[2] sdc1[1]
 +      3907023872 blocks level 5, 64k chunk, algorithm 2 [3/3] [UUU]
 +
 +unused devices: <none>
 +</code>
 +
 +
 +====LVM====
 +
 +Création du bousin LVM : déclaration dans l'ordre :
 +  * d'un volume physique (pv) de 4 To (le raid5)
 +  * d'un groupe de volume (vg) : on ajoute le pv de 4 To qui sera seul dans son groupe
 +  * d'un volume logique (lv) : on déclare une partition de 2 To dans le vg de 4 To (on pourra le redimensionner plus tard).
 +<code bash>
 +pvcreate /dev/md0
 +vgcreate md0_vg /dev/md0
 +lvcreate -L 2T -n data_lv md0_vg
 +</code>
 +
 +Puis on traite ''/dev/md0_vg/data_lv'' comme avec une partition classique :
 +<code bash>
 +# formatage en ext4 avec des paramètres optimisés pour le raid..
 +#(source : http://planet.ubuntu-fr.org/post/2007/10/13/mdadm-raid5)
 +mkfs.ext4 -m 0 -b 4096 -R stride=8 /dev/md0_vg/data_lv
 +
 +# montage automatique au démarrage :
 +echo "/dev/md0_vg/data_lv /mnt/data ext4 defaults 0 1" >> /etc/fstab
 +
 +# montage
 +mkdir /mnt/data
 +mount /mnt/data
 +</code>
 +
 +Vérifications : afficher les résumés des volumes physiques, des groupes de volumes et des volumes logiques :
 +<code bash>
 +pvs
 +  PV         VG     Fmt  Attr PSize  PFree
 +  /dev/md0   md0_vg lvm2 a-    3,64t    0
 +  /dev/sda5  ymir2  lvm2 a-   59,38g    0
 +
 +vgs
 +  VG     #PV #LV #SN Attr   VSize  VFree
 +  md0_vg       0 wz--n-  3,64t    0
 +  ymir2    1     0 wz--n- 59,38g    0
 +
 +lvs
 +  LV      VG     Attr   LSize  Origin Snap%  Move Log Copy%  Convert
 +  data_lv md0_vg -wi-ao  3,64t
 +  root    ymir2  -wi-ao 56,91g
 +  swap_1  ymir2  -wi-ao  2,47g
 +</code>
 +
 +=====Management du raid=====
  
 ====Monitorer son RAID==== ====Monitorer son RAID====
 +
 +<note warning>
 +Attention les commandes qui vont suivre ne proviennent pas toutes du même RAID !
 +</note>
  
 <code> <code>
Line 165: Line 575:
 </code> </code>
  
-====Créer un volume RAID1 avec un seul disque==== +Arrêter/Supprimer le raid : 
-Il s'agit ici de créer un RAID 1 avec un seul disque, donc un RAID en défaut (pas de réplication de données mais la machine fonctionne toujours). Cela permet par exemple de préparer une machine avec un seul disque en attendant la livraison du second.+<code bash> 
 +mdadm --stop /dev/md0 
 + mdadm: stopped /dev/md0 
 +</code>
  
 +Supprimer et ajouter un disque dans une grappe raid :
 +<code bash>
 +mdadm --manage --remove /dev/md0 /dev/sdd1
 + mdadm: hot removed /dev/sdd1 from /dev/md0
 +
 +mdadm --manage --add /dev/md0 /dev/sdd1
 + mdadm: re-added /dev/sdd1
 +</code>
 +
 +Vérifications :
 <code> <code>
-mdadm --create /dev/md0 --level=1 --raid-devices=2 /dev/sda1 missing+mdadm --detail /dev/md0 
 + 
 +mdadm --detail --scan --verbose
 </code> </code>
  
--> On créer /dev/md0 en RAID1 en utilisant 2 partitions : /dev/sda1 et une qui manque en temps normal c'est plus utile d'utiliser une 2nde partition 
  
 +=====Management de LVM=====
  
-=====Création d'un raid5=====+====Augmenter un lv====
  
-Un raid0 avec de la redondance pour la sécurité des données ? C'est un raid5 et c'est ce que je vais tenté ("tenter" car c'est un raid software avec un processeur [[http://fr.wikipedia.org/wiki/Intel_Atom#Pineview|atom n550]], et c'est un processeur un peu léger pour du calcul de parité).+Synopsis : On a un lv ''/dev/md0_vg/data_lv'' de 2 To et on veut le monter à 4 To (soit la taille de son vg).
  
 +Démonter le volume logique (NB : cette étape n'est pas obligatoire avec le système de fichier que j'utilise (ext4), mais vu que mon serveur n'est pas en prod ça ne me coûte pas plus cher) :
 <code bash> <code bash>
-#création de 3 partoches de 1Go avec cfdisk : /dev/sd[bcd]1 +umount /dev/md0_vg/data_lv 
-mdadm --create --verbose /dev/md0 --level=5 --raid-devices=3 /dev/sd[bcd]1+</code>
  
-# il faut attendre un peu le temps de la construction du raid +Augmenter la taille du lv ; attention sa taille ne doit pas dépasser la taille de son volume group (vg), ni être inférieur sa taille actuelle (sinon on perd des données). Pour le vérifier 
-mdadm --detail /dev/md0+<code bash> 
 +# on regarde a quel vg le lv appartient -> md0_vg 
 +lvdisplay /dev/md0_vg/data_lv 
 +  --- Logical volume --- 
 +  LV Name                /dev/md0_vg/data_lv 
 +  VG Name                md0_vg 
 +  LV UUID                WSTrwM-JLAG-Bu9R-GsHw-XVsT-Dpbo-Zm5imT 
 +  LV Write Access        read/write 
 +  LV Status              available 
 +  # open                 0 
 +  LV Size                2,00 TiB 
 +  Current LE             524288 
 +  Segments               1 
 +  Allocation             inherit 
 +  Read ahead sectors     auto 
 +  - currently set to     4096 
 +  Block device           253:2
  
-un fois le raid construitsi tout va bienil faudra le monter automatiquement +on affiche les caractéristique du vg 
-#au démarrage la prochaine fois : +vgdisplay md0_vg 
-echo "DEVICE partitions" >> /etc/mdadm/mdadm.conf +  --- Volume group --- 
-mdadm --detail --scan >> /etc/mdadm/mdadm.conf+  VG Name               md0_vg 
 +  System ID 
 +  Format                lvm2 
 +  Metadata Areas        1 
 +  Metadata Sequence No  2 
 +  VG Access             read/write 
 +  VG Status             resizable 
 +  MAX LV                0 
 +  Cur LV                1 
 +  Open LV               0 
 +  Max PV                0 
 +  Cur PV                1 
 +  Act PV                1 
 +  VG Size               3,64 TiB 
 +  PE Size               4,00 MiB 
 +  Total PE              953862 
 +  Alloc PE Size       524288 2,00 TiB 
 +  Free  PE Size       429574 / 1,64 TiB 
 +  VG UUID               1g20v1-7HKi-CWtx-D8IP-GS9P-rTfB-nL9WHr 
 +</code> 
 +On a bien 3.64TiB au total soit 4 To.
  
-# formatage en ext2 avec des paramètres qu'il parait qu'ils sont bien.. +On pourrait déclarer une nouvelle taille de 3.64 TiB (''-L 3.64T''), ou ajouter 1.64 To (''-L +1.64T'') - pour toutes les options existantes, consulter le ''man lvresize'' mais on veut la taille totale du vg donc on va être précis et utiliser l'option ''-l +100%FREE'' qui indique qu'on ajoute toute la place libre restante du vg : 
-#(source : http://planet.ubuntu-fr.org/post/2007/10/13/mdadm-raid5) +<code bash> 
-mke2fs --b 4096 -R stride=8 /dev/md0+lvresize -l +100%FREE /dev/md0_vg/data_lv 
 +  Extending logical volume data_lv to 3,64 TiB 
 +  Logical volume data_lv successfully resized 
 +</code>
  
-# montage automatique +On doit ensuite vérifier l'intégrité du volume logique 
-echo "/dev/md0 /mnt/data auto defaults 3" >> /etc/fstab+<code bash> 
 +e2fsck -f /dev/md0_vg/data_lv 
 + e2fsck 1.41.12 (17-May-2010) 
 + Passe 1 : vérification des i-noeuds, des blocs et des tailles 
 + Passe 2 : vérification de la structure des répertoires 
 + Passe 3 : vérification de la connectivité des répertoires 
 + Passe 4 : vérification des compteurs de référence 
 + Passe 5 : vérification de l'information du sommaire de groupe 
 + /dev/md0_vg/data_lv : 11/201326592 fichiers (0.0% non contigus), 12687388/805306368 blocs 
 +</code>
  
-# montage +Puis on étend le système de fichier : 
-mkdir /mnt/data +<code bash> 
-mount /mnt/data+resize2fs /dev/md0_vg/data_lv 
 + resize2fs 1.41.12 (17-May-2010) 
 + En train de retailler le système de fichiers sur /dev/md0_vg/data_lv à 976754688 (4k) blocs. 
 + Le système de fichiers /dev/md0_vg/data_lv a maintenant une taille de 976754688 blocs.
 </code> </code>
  
 +et on remonte le lv :
 +<code bash>
 +mount /dev/md0_vg/data_lv
 +
 +df -Th /mnt/data
 + Sys. fich.    Type  Taille  Uti. Disp. Uti% Monté sur
 + /dev/mapper/md0_vg-data_lv
 +             ext4    3,6T  196M  3,6T   1% /mnt/data
 +</code>
  
 =====Tests et banchmarks===== =====Tests et banchmarks=====
Line 318: Line 804:
  
 Étonnant : on a un meilleur débit en écriture qu'en lecture sur ce raid0... Étonnant : on a un meilleur débit en écriture qu'en lecture sur ce raid0...
 +
 +
 +=====Test avec bonnie++=====
 +
 +bonnie++ est un logiciel tierce qui mesure les performances d'un disque.
 +
 +
 +=====Suppression totale d'un volume RAID=====
 +
 +Parce que mdadm est coriace, et que la procédure de suppression d'un RAID pour récupérer les disques n'est pas si anodine que cela, voici une petite check-list :
 +
 +Supprimer les metadata avec dmraid
 +<code bash>
 +sudo dmraid -r -E /dev/sdb
 +no raid disks and with names: "/dev/sdb"
 +
 +sudo dmraid -r -E /dev/sdc
 +Do you really want to erase "ddf1" ondisk metadata on /dev/sdc ? [y/n] :y
 +ERROR: ddf1: seeking device "/dev/sdc" to 1024204253954048
 +ERROR: writing metadata to /dev/sdc, offset 2000398933504 sectors, size 0 bytes returned 0
 +ERROR: erasing ondisk metadata on /dev/sdc
 +
 +sudo dmraid -r -E /dev/sdd
 +Do you really want to erase "ddf1" ondisk metadata on /dev/sdd ? [y/n] :y
 +ERROR: ddf1: seeking device "/dev/sdd" to 1024204253954048
 +ERROR: writing metadata to /dev/sdd, offset 2000398933504 sectors, size 0 bytes returned 0
 +ERROR: erasing ondisk metadata on /dev/sdd
 +</code>
 +
 +Si ça ne marche pas on observe encore :
 +<code bash>
 +cat /proc/mdstat
 +Personalities : [linear] [multipath] [raid0] [raid1] [raid6] [raid5] [raid4] [raid10]
 +md0 : inactive sdd[0](S) sdb[2](S)
 +      3907028992 blocks
 +unused devices: <none>
 +</code>
 +
 +<code bash>
 +umount /dev/md0
 +mdadm --manage /dev/md0 --stop
 +mdadm --manage /dev/md0 --remove
 +rm /etc/mdadm/mdadm.conf
 +</code>
 +
 +Suppression de la partition "raid" de chaque disque
 +<code bash>
 +sudo fdisk /dev/sdb
 +d
 +p
 +w
 +</code>
 +
 +On efface les superblocks :
 +<code bash>
 +sudo mdadm --zero-superblock /dev/sdb
 +sudo mdadm --zero-superblock /dev/sdb1
 +mdadm: Couldn't open /dev/sdb1 for write - not zeroing
 +</code>
 +
 +Cela évite de se retrouver bloquer au boot par le prompt busybox !
 +
 +Dans mon cas au reboot un nouveau volume raid est apparu tout seul : "md127". Il y a une procédure avec Ubuntu pour l'éradiquer (source : http://ubuntuforums.org/showthread.php?t=1764861%29: ) :
 +<code bash>
 +sudo update-initramfs -u
 +sudo reboot
 +</code>
  
  
informatique/linux/raid0_sous_linux.txt · Last modified: 2024/06/29 14:10 by pteu