Software Raid: Difference between revisions

From Q
Jump to navigation Jump to search
Zulasch (talk | contribs)
Die Seite wurde neu angelegt: WICHTIG!!! Ihr wisst schon: Bitte macht ein Backup vorher! Dieses HowTo beschreibt wie man ein Raid 1 Online umpartitionieren kann d.h. es muss nicht in einem Rescu Mo...
 
Tgurr (talk | contribs)
No edit summary
 
(11 intermediate revisions by 2 users not shown)
Line 1: Line 1:
== Hinweise ==
WICHTIG!!!
WICHTIG!!!
Ihr wisst schon: Bitte macht ein Backup vorher!
Ihr wisst schon: Bitte macht ein Backup vorher!
Line 6: Line 8:
Ich habe 2 Festplatten mit je 160 GB davon möchte ich 100 GB auf eine andere Partition haben.  
Ich habe 2 Festplatten mit je 160 GB davon möchte ich 100 GB auf eine andere Partition haben.  


{{Box File|Ist und Soll Stand|
{{Code|Ist und Soll Stand|
<pre>
<pre>


Line 24: Line 26:




== Apache Konfiguration ==
== Raid konfigurieren ==


{{Box File| text  |
{{Code||
<pre>
<pre>
# Initiate a RAID5 setup for testing purposes:
# Zuerst erstellen wir ein Raid 1:
mdadm --create --verbose /dev/md0 --level=5 --raid-devices=3 /dev/hda1 /dev/hdb1 /dev/hdd1
mdadm --create --verbose /dev/md1 --level=1 --raid-devices=2 /dev/sda1 /dev/sdb1


# Create filesystem, mount md0, create a testfile and save md5sum for later check:
# dateisystem erstellen,  
mkfs.ext3 /dev/md0
mkfs.ext3 /dev/md1
mount /dev/md0 /mnt/test
 
# md0 Raid mounten,
mount /dev/md1 /mnt/test
 
# Erstellen einer Testdatei und md5sum um es später wieder zu prüfen:
dd if=/dev/urandom of=/mnt/test/dd bs=512 count=10000
dd if=/dev/urandom of=/mnt/test/dd bs=512 count=10000
md5sum /mnt/test/dd > md5sum
md5sum /mnt/test/dd > md5sum


# Make sure the RAID is synched via checking:
# Unbedingt prüfen ob das Raid syncronisiert ist:
cat /proc/mdstat
cat /proc/mdstat


# Now remove one partition:
# Nun entfernen wir eine Partition:
mdadm /dev/md0 --fail /dev/hdd1 --remove /dev/hdd1
mdadm /dev/md1 --fail /dev/sda1 --remove /dev/sda1


# Delete partition, create a new + bigger one and set partition type to fd (Linux raid autodetect):
# und löschen wir die sda1, erstellen eine neue (kleinere) und setzen den Partitionstyp auf fd (Linux raid autodetect):
cfdisk /dev/hdd
cfdisk /dev/sda


# And re-add the partition:
# Partition dem Raid wieder hinzufügen:
mdadm -a /dev/md0 /dev/hdd1
mdadm -a /dev/md1 /dev/sda1


# Make sure the RAID is synched via checking:
# Unbedingt wieder prüfen ob das Raid syncronisiert ist:
cat /proc/mdstat
cat /proc/mdstat


# Repeat the steps for all other disks/partitions as well:
Das Ganze lässt sich natürlich auch für mehrere Festplatten wiederholen. <br/>
mdadm /dev/md0 --fail /dev/hdb1 --remove /dev/hdb1
also Egal ob Raid 1 oder 5. Ausser stripes natürlich.
cfdisk /dev/hdb
 
mdadm -a /dev/md0 /dev/hdb1
 
cat /proc/mdstat
Nun wird das Raid auf die neue Größe anegpasst:
mdadm /dev/md0 --fail /dev/hda1 --remove /dev/hda1
 
cfdisk /dev/hda
# mdadm --detail /dev/md1 | grep -e 'Array Size' -e 'Device Size'
mdadm -a /dev/md0 /dev/hda1
    Array Size : 390912 (381.81 MiB 400.29 MB)
cat /proc/mdstat
    Device Size : 195456 (190.91 MiB 200.15 MB)
 
# mdadm --grow /dev/md1 -z max
# mdadm --detail /dev/md1 | grep -e "Array Size" -e 'Device Size'
    Array Size : 976512 (953.79 MiB 999.95 MB)
    Device Size : 488256 (476.89 MiB 499.97 MB)
 
 
# df -h | grep test
/dev/md1              370M  15M  336M  5% /mnt/test
 
# resize2fs /dev/md1
resize2fs 1.39 (29-May-2006)
Filesystem at /dev/md1 is mounted on /mnt/test; on-line resizing required
Performing an on-line resize of /dev/md1 to 976512 (1k) blocks.
The filesystem on /dev/md1 is now 976512 blocks long.
 
# df -h | grep test
/dev/md1              924M  16M  861M  2% /mnt/test
 
Nun die testdatei checken:
 
# md5sum -c md5sum
/mnt/test/dd: OK
 


Als letztes erstellen wir die neue Patition ebenfalls in einem Raid 1 Verbund:
# mdadm --create /dev/md2 --level=1 --raid-devices=2 /dev/sda4 /dev/sdb4


</pre>
Jetzt noch ein Dateisystem drauf:
}}
# mkfs.ext3 /dev/md2




== Installation ==
Fertig!!!


{{Codeline|# emerge phpmyadmin}}
</pre>
}}

Latest revision as of 15:17, 27 July 2011

Hinweise

WICHTIG!!! Ihr wisst schon: Bitte macht ein Backup vorher!

Dieses HowTo beschreibt wie man ein Raid 1 Online umpartitionieren kann d.h. es muss nicht in einem Rescu Modus oder von eine externe CD gebootet werden. Das ist der Vorteil beim Raid man kann eine Platte entfernen und wieder hinzufügen und das ganze wärend dem Betrieb. Ich habe 2 Festplatten mit je 160 GB davon möchte ich 100 GB auf eine andere Partition haben.

Code: Ist und Soll Stand

Vorhandene Festplatten im Server:
HDD1 = /dev/sda 160 GB
HDD2 = /dev/sbb 160 GB

IST Stand:
MD1 = 160 GB (2x 160 GB Raid 1) 

SOLL Stand:
MD1 = 60 GB (2x 60 GB Raid 1)
MD2 = 100 GB (2x 100 GB Raid 1)


Raid konfigurieren

Code:
# Zuerst erstellen wir ein Raid 1:
mdadm --create --verbose /dev/md1 --level=1 --raid-devices=2 /dev/sda1 /dev/sdb1

# dateisystem erstellen, 
mkfs.ext3 /dev/md1

# md0 Raid mounten, 
mount /dev/md1 /mnt/test

# Erstellen einer Testdatei und md5sum um es später wieder zu prüfen:
dd if=/dev/urandom of=/mnt/test/dd bs=512 count=10000
md5sum /mnt/test/dd > md5sum

# Unbedingt prüfen ob das Raid syncronisiert ist:
cat /proc/mdstat

# Nun entfernen wir eine Partition:
mdadm /dev/md1 --fail /dev/sda1 --remove /dev/sda1

# und löschen wir die sda1, erstellen eine neue (kleinere) und setzen den Partitionstyp auf fd (Linux raid autodetect):
cfdisk /dev/sda

# Partition dem Raid wieder hinzufügen:
mdadm -a /dev/md1 /dev/sda1

# Unbedingt wieder prüfen ob das Raid syncronisiert ist:
cat /proc/mdstat

Das Ganze lässt sich natürlich auch für mehrere Festplatten wiederholen. <br/>
also Egal ob Raid 1 oder 5. Ausser stripes natürlich.


Nun wird das Raid auf die neue Größe anegpasst:

# mdadm --detail /dev/md1 | grep -e 'Array Size' -e 'Device Size'
    Array Size : 390912 (381.81 MiB 400.29 MB)
    Device Size : 195456 (190.91 MiB 200.15 MB)

# mdadm --grow /dev/md1 -z max
# mdadm --detail /dev/md1 | grep -e "Array Size" -e 'Device Size'
    Array Size : 976512 (953.79 MiB 999.95 MB)
    Device Size : 488256 (476.89 MiB 499.97 MB)


# df -h | grep test
/dev/md1              370M   15M  336M   5% /mnt/test

# resize2fs /dev/md1
resize2fs 1.39 (29-May-2006)
Filesystem at /dev/md1 is mounted on /mnt/test; on-line resizing required
Performing an on-line resize of /dev/md1 to 976512 (1k) blocks.
The filesystem on /dev/md1 is now 976512 blocks long.

# df -h | grep test
/dev/md1              924M   16M  861M   2% /mnt/test

Nun die testdatei checken:

# md5sum -c md5sum
/mnt/test/dd: OK


Als letztes erstellen wir die neue Patition ebenfalls in einem Raid 1 Verbund:
# mdadm --create /dev/md2 --level=1 --raid-devices=2 /dev/sda4 /dev/sdb4

Jetzt noch ein Dateisystem drauf:
# mkfs.ext3 /dev/md2


Fertig!!!