Difference between revisions of "Mdadm"
(Created page with "There are a few options for software RAID on Gnu Linux. Among them is BtrFS and ZFS (the latter of which has licensing issues, so use discretion before using)., however today...") |
|||
(8 intermediate revisions by one other user not shown) | |||
Line 1: | Line 1: | ||
− | There are a few options for software RAID on Gnu Linux. Among them is BtrFS and ZFS (the latter of which has licensing issues, so use discretion before using)., however today I will focus on mdadm. This is historically the oldest software raid, therefore should be better vetted, although its performance may be less of that of the first two mentioned - for simple servers, mdadm might be the most stable choice. | + | There are a few options for software RAID on Gnu Linux. Among them is BtrFS and ZFS (the latter of which has licensing issues, so use discretion before using)., however today I will focus on mdadm. This is historically the oldest software raid, therefore should be better vetted, although its performance may be less of that of the first two mentioned - for simple servers, mdadm might be the most stable choice. However, after testing it in practice I found that it was not stable on 1 out of 2 machines. The general rule that 'software RAID is not trustworthy' might apply here. Generally, go with hardware RAID. |
==Creation of RAID== | ==Creation of RAID== | ||
Line 6: | Line 6: | ||
==Usage== | ==Usage== | ||
− | + | ===Status / Details=== | |
# sudo mdadm -D /dev/md127 | # sudo mdadm -D /dev/md127 | ||
<pre> | <pre> | ||
Line 38: | Line 38: | ||
− | ==Add Drive to | + | ===Add Drive to Array=== |
+ | This assumes you have already created the RAID. This is for adding to an existing array. | ||
# mdadm --add /dev/md127 /dev/sda1 | # mdadm --add /dev/md127 /dev/sda1 | ||
− | NOTE: If you setup 2 hdds, in a raid, and want to add a third, if you just --add, it will show up as a spare... | + | <small>NOTE: If you setup 2 hdds, in a raid, and want to add a third, if you just --add, it will show up as a spare... |
if you do mdadm --grow /dev/md127 -raid-devices=3 then the third might be active sync (what we want) | if you do mdadm --grow /dev/md127 -raid-devices=3 then the third might be active sync (what we want) | ||
Line 50: | Line 51: | ||
NOTE: if you have a new drive and need to copy the hdd partition tables: | NOTE: if you have a new drive and need to copy the hdd partition tables: | ||
https://unix.stackexchange.com/questions/12986/how-to-copy-the-partition-layout-of-a-whole-disk-using-standard-tools | https://unix.stackexchange.com/questions/12986/how-to-copy-the-partition-layout-of-a-whole-disk-using-standard-tools | ||
− | or aka | + | or aka</small> |
<pre> | <pre> | ||
(FOR MBR ONLY) | (FOR MBR ONLY) | ||
Line 130: | Line 131: | ||
'''WARNING:''' Reinstall grub on the new drive again as well afterwards. | '''WARNING:''' Reinstall grub on the new drive again as well afterwards. | ||
− | ===Email Notifications | + | ===Email Notifications=== |
Test emails on mdadm.. first configure email however you prefer (i currently use ssmtp). | Test emails on mdadm.. first configure email however you prefer (i currently use ssmtp). | ||
− | edit /etc/mdadm/mdadm.conf | + | edit /etc/mdadm/mdadm.conf; put the email recipient in mailadd variable |
then | then | ||
<pre> | <pre> | ||
− | + | # mdadm --monitor --scan --test --oneshot | |
</pre> | </pre> | ||
should send an email | should send an email | ||
+ | |||
+ | <small>(Be careful that updates don't break this file. I see it's generated by mkconf.)</small> | ||
Line 153: | Line 156: | ||
General partition tips: | General partition tips: | ||
https://github.com/zfsonlinux/zfs/wiki/Debian-Stretch-Root-on-ZFS | https://github.com/zfsonlinux/zfs/wiki/Debian-Stretch-Root-on-ZFS | ||
+ | |||
+ | Configuring Email w/ssmtp: | ||
+ | https://wiki.zoneminder.com/SMS_Notifications | ||
+ | |||
+ | {{GNU\Linux}} |
Latest revision as of 05:50, 16 April 2023
There are a few options for software RAID on Gnu Linux. Among them is BtrFS and ZFS (the latter of which has licensing issues, so use discretion before using)., however today I will focus on mdadm. This is historically the oldest software raid, therefore should be better vetted, although its performance may be less of that of the first two mentioned - for simple servers, mdadm might be the most stable choice. However, after testing it in practice I found that it was not stable on 1 out of 2 machines. The general rule that 'software RAID is not trustworthy' might apply here. Generally, go with hardware RAID.
Creation of RAID
Will not be covered here (yet). You must create the partition tables. Create the raid with mdadm. mkfs.ext4 on the raid partition. Add mdadm to grub config. Reinstall grub. Details may be provided later.
Usage
Status / Details
# sudo mdadm -D /dev/md127
/dev/md127: Version : 1.2 Creation Time : Fri Feb 1 01:00:25 2019 Raid Level : raid1 Array Size : 57638912 (54.97 GiB 59.02 GB) Used Dev Size : 57638912 (54.97 GiB 59.02 GB) Raid Devices : 3 Total Devices : 2 Persistence : Superblock is persistent Update Time : Fri Feb 1 02:40:44 2019 State : clean, degraded Active Devices : 2 Working Devices : 2 Failed Devices : 0 Spare Devices : 0 Name : devuan:root UUID : 83a8dc03:802a4129:26322116:c2cfe1d4 Events : 82 Number Major Minor RaidDevice State - 0 0 0 removed 1 8 17 1 active sync /dev/sdb1 2 8 33 2 active sync /dev/sdc1
(here you can see, one was removed. It auto removes, when unplugged)
Add Drive to Array
This assumes you have already created the RAID. This is for adding to an existing array.
# mdadm --add /dev/md127 /dev/sda1
NOTE: If you setup 2 hdds, in a raid, and want to add a third, if you just --add, it will show up as a spare...
if you do mdadm --grow /dev/md127 -raid-devices=3 then the third might be active sync (what we want) note that the --grow, seems to allow for parameter changes after you have already created the raid. you can also specify the exact same command, raid-devices=3 in the setup of the raid (see install doc). Note that if you lose a drive, you can simply add it.
NOTE: don't worry about mkfs.ext4 on the raid members, after initial setup. The RAID will manage that.
NOTE: if you have a new drive and need to copy the hdd partition tables: https://unix.stackexchange.com/questions/12986/how-to-copy-the-partition-layout-of-a-whole-disk-using-standard-tools or aka
(FOR MBR ONLY) Save: sfdisk -d /dev/sda > part_table Restore: sfdisk /dev/NEWHDD < part_table (FOR GPT:) # Save MBR disks sgdisk --backup=/partitions-backup-$(basename $source).sgdisk $source sgdisk --backup=/partitions-backup-$(basename $dest).sgdisk $dest # Copy $source layout to $dest and regenerate GUIDs sgdisk --replicate=$dest $source sgdisk -G $dest
Add HDD back to RAID (to fix failed drive)
# mdadm --add /dev/md127 /dev/sda1 mdadm: added /dev/sda1 # sudo mdadm -D /dev/md127 /dev/md127: Version : 1.2 Creation Time : Fri Feb 1 01:00:25 2019 Raid Level : raid1 Array Size : 57638912 (54.97 GiB 59.02 GB) Used Dev Size : 57638912 (54.97 GiB 59.02 GB) Raid Devices : 3 Total Devices : 3 Persistence : Superblock is persistent Update Time : Fri Feb 1 02:41:43 2019 State : clean, degraded, recovering Active Devices : 2 Working Devices : 3 Failed Devices : 0 Spare Devices : 1 Rebuild Status : 0% complete Name : devuan:root UUID : 83a8dc03:802a4129:26322116:c2cfe1d4 Events : 92 Number Major Minor RaidDevice State 3 8 1 0 spare rebuilding /dev/sda1 1 8 17 1 active sync /dev/sdb1 2 8 33 2 active sync /dev/sdc1
You can check on the rebuild partway:
Rebuild Status : 6% complete Name : devuan:root UUID : 83a8dc03:802a4129:26322116:c2cfe1d4 Events : 103 Number Major Minor RaidDevice State 3 8 1 0 spare rebuilding /dev/sda1 1 8 17 1 active sync /dev/sdb1 2 8 33 2 active sync /dev/sdc1
You can also watch it via /proc/
watch -n1 cat /proc/mdstat
Every 1.0s: cat /proc/mdstat server: Fri Feb 1 02:43:24 2019 Personalities : [raid1] [linear] [multipath] [raid0] [raid6] [raid5] [raid4] [raid10] md127 : active raid1 sda1[3] sdb1[1] sdc1[2] 57638912 blocks super 1.2 [3/2] [_UU] [==>..................] recovery = 11.2% (6471936/57638912) finish=13.2min speed=64324K/sec unused devices: <none>
WARNING: Reinstall grub on the new drive again as well afterwards.
Email Notifications
Test emails on mdadm.. first configure email however you prefer (i currently use ssmtp).
edit /etc/mdadm/mdadm.conf; put the email recipient in mailadd variable
then
# mdadm --monitor --scan --test --oneshot
should send an email
(Be careful that updates don't break this file. I see it's generated by mkconf.)
https://ubuntuforums.org/showthread.php?t=1185134
for more details on email sending
External Links
The section about degraded disks: https://help.ubuntu.com/lts/serverguide/advanced-installation.html.en
General partition tips: https://github.com/zfsonlinux/zfs/wiki/Debian-Stretch-Root-on-ZFS
Configuring Email w/ssmtp: https://wiki.zoneminder.com/SMS_Notifications
|