Mastodon Mastodon Mastodon Systeemkabouter blog – Using spare M2 storage to create RAID1 set

Using spare M2 storage to create RAID1 set

Posted on zo 12 februari 2023 in hardware

The slimbook I ordered was ordered with the basic specs. As soon as I was convinced the laptop would be worthwhile, I ordered extra RAM and storage capacity.

So next to the 256 GB NVME storage I installed a 1 TB M2 stick. I reinstalled the operating on the new storage device, but while setting partitions I set about 256 GB of space aside for later use.

Later is now and I just setup a small RAID1 device using linux mdadm, running a encrypted container on top. I intend to use this storage to run virtual machines for improved read performance and maybe to secure more sensitive data from data loss.

Setting up was pretty straighforward, but is documented here for future reference:

  • created two new partitions, accepting they are not exactly the same size
root@tux:~# fdisk -l /dev/nvme0n1
Disk /dev/nvme0n1: 232,91 GiB, 250059350016 bytes, 488397168 sectors
Disk model: Samsung SSD 980 250GB                   
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 16384 bytes / 131072 bytes
Disklabel type: gpt
Disk identifier: 4925E21F-2FAD-4480-89F4-429C4D3F3BF4

Device           Start       End   Sectors   Size Type
/dev/nvme0n1p1    2048   1050623   1048576   512M EFI System
/dev/nvme0n1p2 1050624 488397134 487346511 232,4G Linux RAID


root@tux:~# fdisk -l /dev/nvme1n1
Disk /dev/nvme1n1: 931,53 GiB, 1000204886016 bytes, 1953525168 sectors
Disk model: Samsung SSD 980 PRO 1TB                 
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: gpt
Disk identifier: 99B17A0E-A5DA-4D54-92C1-7CE85AC8BC1A

Device              Start        End    Sectors   Size Type
/dev/nvme1n1p1       2048    1046527    1044480   510M EFI System
/dev/nvme1n1p2    1046528    3047423    2000896   977M Linux filesystem
/dev/nvme1n1p3    3047424 1455472639 1452425216 692,6G Linux filesystem
/dev/nvme1n1p4 1455472640 1953525134  498052495 237,5G Linux RAID

so apparently I lost about 5 GB of disk storage, I will live.

Then I created the RAID1 md0 device:

root@tux:~# mdadm --create --verbose /dev/md0 --level=1 --raid-devices=2 /dev/nvme0n1p2 /dev/nvme1n1p4
mdadm: /dev/nvme0n1p2 appears to contain an ext2fs file system
       size=749568K  mtime=Thu Feb  9 17:12:57 2023
mdadm: Note: this array has metadata at the start and
    may not be suitable as a boot device.  If you plan to
    store '/boot' on this device please ensure that
    your boot-loader understands md/v1.x metadata, or use
    --metadata=0.90
mdadm: size set to 243541120K
mdadm: automatically enabling write-intent bitmap on large array
mdadm: largest drive (/dev/nvme1n1p4) exceeds size (243541120K) by more than 1%
Continue creating array? yes
mdadm: Defaulting to version 1.2 metadata
mdadm: array /dev/md0 started.

than I created the encrypted container on top of the md0 raid device:

root@tux:~# cryptsetup -y -v --type luks1 luksFormat /dev/md0
WARNING: Device /dev/md0 already contains a 'gpt' partition signature.

WARNING!
========
This will overwrite data on /dev/md0 irrevocably.

Are you sure? (Type uppercase yes): YES
Enter passphrase for /dev/md0: 
Verify passphrase: 
Existing 'gpt' partition signature (offset: 512 bytes) on device /dev/md0 will be wiped.
Existing 'gpt' partition signature (offset: 249386106368 bytes) on device /dev/md0 will be wiped.
Existing 'PMBR' partition signature (offset: 510 bytes) on device /dev/md0 will be wiped.
Key slot 0 created.
Command successful.

check the mdstatus to see if RAID syncing was coming along:

root@tux:~# more /proc/mdstat 
Personalities : [linear] [multipath] [raid0] [raid1] [raid6] [raid5] [raid4] [raid10] 
md0 : active raid1 nvme1n1p4[1] nvme0n1p2[0]
      243541120 blocks super 1.2 [2/2] [UU]
      [================>....]  resync = 82.7% (201448064/243541120) finish=3.3min speed=210509K/sec
      bitmap: 1/2 pages [4KB], 65536KB chunk

unused devices: <none>

almost done there.

Then it was just a case off unlocking the device, formatting it and mounting it somewhere

root@tux:~# cryptsetup luksOpen /dev/md0 datavol
Enter passphrase for /dev/md0: 
root@tux:~# mkfs.btrfs /dev/mapper/datavol 
root@tux:~# cryptsetup luksOpen /dev/md0 datavol
Enter passphrase for /dev/md0: 
root@tux:~# ls /dev/mapper/
control  datavol  nvme1n1p3_crypt
root@tux:~# mkfs.btrfs /dev/mapper/datavol