this post was submitted on 25 Jul 2024
49 points (96.2% liked)

Selfhosted

41012 readers
2006 users here now

A place to share alternatives to popular online services that can be self-hosted without giving up privacy or locking you into a service you don't control.

Rules:

  1. Be civil: we're here to support and learn from one another. Insults won't be tolerated. Flame wars are frowned upon.

  2. No spam posting.

  3. Posts have to be centered around self-hosting. There are other communities for discussing hardware or home computing. If it's not obvious why your post topic revolves around selfhosting, please include details to make it clear.

  4. Don't duplicate the full text of your blog or github here. Just post the link for folks to click.

  5. Submission headline should match the article title (don’t cherry-pick information from the title to fit your agenda).

  6. No trolling.

Resources:

Any issues on the community? Report it using the report flag.

Questions? DM the mods!

founded 2 years ago
MODERATORS
 

Its new homelab time. And with that, potentially a new OS time too.

I currently am very happy with Debian and Docker. The only issue is I am brand new to using data redundancy. I have a 2 bay NAS I'll use, and I want the two HDDs to be in raid 1.

Now I could definitely just use ZFS or BTRFS with Debian, and be able to use Docker just like I do currently.

Or I could use a dedicated NAS OS. That would help me with the raid part of this, but a requirement is Docker.

Any recommendations?

all 45 comments
sorted by: hot top controversial new old
[–] [email protected] 28 points 5 months ago (3 children)

Debian and the standard linux mdraid?

[–] [email protected] 11 points 5 months ago

This. Don't make it unnecessarily complicated.

[–] Dust0741 10 points 5 months ago (2 children)
[–] [email protected] 5 points 5 months ago

Yeah, that's what he means.

I'm doing kinda the same thing with my NAS: md raid1 for the SSDs, but only snapraid for the big data drives (mostly because I don't really care if i have to re-download my linux iso collection, so snapraid plus mergerfs is like, sufficient for that data).

Also using Ubuntu instead of Debian, but that's mostly due to it being first built six years ago, and I'd 100% go with Debian if I was doing it now.

[–] [email protected] 2 points 5 months ago (1 children)

Yes, as the other people pointed out, that's what I mean. The standard Linux software RAID (also called MD RAID)

It's proven, battle-tested, pretty robust and you don't rely on any specific vendor formats or any hardware for that matter. The main point would be to keep it simple. You could use BTRFS or ZFS or all kinds of things. But it only introduces additional complexity and points of failure. And has no benefits over a plain mirror (what the RAID1 does) if we're talking about just 2 devices. At least it served me well in the past. Contrary to cheap hardware RAID controllers and also BTRFS which also let me down once. But a lot of development went in to that since then and the situation might have changed. But mdraid is reliable anyways.

[–] [email protected] 2 points 5 months ago (1 children)
[–] [email protected] 1 points 5 months ago* (last edited 5 months ago) (1 children)

That is indeed a good question. Is this something RAID is bothered with at levels 0 and 1? I think in this case it's the job of the filesystem to care for that. But you should probably let the periodic task run that does scrubbing like once per week. You could also experience other issues than just bitrot. For example bad sectors and one of the hdds slowly degrading.

In the end I don't think a RAID1 can do much about bitrot and other RAID woes. There are no checksums or anything to correct for that. You'd probably need some other technology for that. But it's probably the same for a ZFS mirror. And everything better than that needs more than 2 hdds.

[–] [email protected] 1 points 5 months ago

I think ZFS does some advanced stuff which makes it better than just relying on hardware checksums (which have been shown to not be so great)

[–] [email protected] 1 points 5 months ago

I'd suggest lvmraid which is just mdraid wrapped in LVM. It's a tad simpler to setup and you get the flexibility of LVM, plus the ability to convert from linear to mirror and back as needed. That is you could do a standard install on LVM, then add another disk to LVM and convert the volumes to RAID1. It's all documented under man lvmraid.

[–] just_another_person 14 points 5 months ago (2 children)

Unraid and Truenas are pretty popular. Openmediavault is less popular, but a pretty simple system based on Debian.

[–] [email protected] 4 points 5 months ago (1 children)

I've been happy with unraid, super simple to use and the community apps makes it easy to find and install docker containers

[–] [email protected] 5 points 5 months ago* (last edited 5 months ago) (2 children)

Unraid is great and I have been using it for over a decade now, but a paid OS on a 2bay nas seems excessive

[–] [email protected] 1 points 5 months ago

Yeah plus the pricing change where you only get so many updates now kind of bucks but it was bound to happen

[–] [email protected] 3 points 5 months ago (2 children)

TrueNAS SCALE expects you to deploy Kubernetes clusters, it is unfortunately not meant for running plain Docker. You can jump through hoops to get it working but I personally gave up and ended up running a VM on top of TrueNAS just to run Docker on it.

I don't know about Unraid though and OpenMediaVault felt a bit unpolished the last time I used it and I can't attest for its ZFS support.

[–] Mrb2 9 points 5 months ago (1 children)

Truenas scale is switching to docker compose. I found this out when the truecharts catalog suddenly stopped working. more info

[–] [email protected] 3 points 5 months ago

Holy molly, I wasn't expecting this! Well, I guess I'll try that out once Electric Eel's released

[–] [email protected] 2 points 5 months ago

I am currently using Openmediavault for my NAS and can confirm that with an official plugin so far I havent had any issue with my ZFS pool (that I migrated from trueNAS scale since I didn't like their kubernetes use and truecharts, but as someone mentions they seem to switch to docker).

Otherwise I am happy as well, but I am far from a poweruser.

[–] [email protected] 9 points 5 months ago

Generally, I think it is better to use a general server OS like Debian or Fedora instead of something specialized like Proxmox or Unraid. That way you can always choose the way you want to use your server instead of being channeled into running it a specific way (especially if you ever change your mind).

[–] [email protected] 6 points 5 months ago (2 children)

I run Debian with zfs. Really simple to set up and has been rock solid for it too. As far as I can tell all the issues I've had have been my fault.

ZFS looks like it uses a lot of RAM, but you can get away without it if you need too. It's basically extra caching. I was thrilled to use it as an excuse to upgrade my ram instead.

Mdadm has a little more setup then zfs, as far as I'm concerned. You need to set your own scrubbing up whereas zfs schedules it's own for you. You need to add monitoring stuff for both though.

I've considered looking into the various operating systems designsd for this, but they just don't seem to be worth the effort of switching to me.

[–] [email protected] 3 points 5 months ago

I can also recommend zfs on debian. Even if you only using two disks you will be still protected from bit rot.

[–] Dust0741 1 points 5 months ago (1 children)

Any recomended monitoring solutions? Or just proxmox and grafana?

[–] [email protected] 4 points 5 months ago (1 children)

I can recommend dockprom. It comes with grafana preconfigured.

[–] Dust0741 2 points 5 months ago
[–] [email protected] 6 points 5 months ago

Proxmox ZFS with plenty of ram. (ZFS is ram heavy)

[–] [email protected] 5 points 5 months ago* (last edited 5 months ago)

Acronyms, initialisms, abbreviations, contractions, and other phrases which expand to something larger, that I've seen in this thread:

Fewer Letters More Letters
LVM (Linux) Logical Volume Manager for filesystem mapping
NAS Network-Attached Storage
RAID Redundant Array of Independent Disks for mass storage
SSD Solid State Drive mass storage
ZFS Solaris/Linux filesystem focusing on data integrity

5 acronyms in this thread; the most compressed thread commented on today has 20 acronyms.

[Thread #887 for this sub, first seen 25th Jul 2024, 15:45] [FAQ] [Full list] [Contact] [Source code]

[–] [email protected] 3 points 5 months ago

Honestly, from your description, I'd go with Debian, likely with btrfs. Would be better if you had 3 slots so that you can swap a bad drive but, 2 will work.

If you want to get adventurous, you can see about a Fedora Atomic distro.

Previously, I've recommended Proxmox but, not sure that I still can at the moment, if they haven't fixed their kernel funkiness. Right now, I'm back to libvirt.

[–] [email protected] 3 points 5 months ago (1 children)

Bog-standard Debian with LVM. LVM can also do RAID, but you could also do mdadm below LVM if you prefer. Keep it simple.

[–] [email protected] 1 points 5 months ago (1 children)

Not as powerful as btrfs or zfs

[–] [email protected] 3 points 5 months ago

ZFS isn't built-in. I don't know enough about btrfs to recommend it.

[–] [email protected] 3 points 5 months ago (1 children)

Definitely use ZFS for the data volumes in order to avoid silent data corruption. If you don't use separate drive for the OS, then you need to look into ZFS on root.

[–] [email protected] 1 points 5 months ago
[–] [email protected] 3 points 5 months ago (1 children)

I'm very new to the whole ordeal but to my knowledge ZFS and, less so BTRFS are a bit too rigid for my setup, I'm personally looking at Debian with mergerFS and SnapRAID.

[–] [email protected] 1 points 5 months ago (1 children)

ZFS is rigid? Please explain

[–] [email protected] 1 points 5 months ago (1 children)

I need to throw random spare old HDs at it, I expect failures, I expect expanding it, I expect very different sizes between the disks.

[–] [email protected] 1 points 5 months ago

You can do that with ZFS. It's built-in integrierty check will automatically heal errors and tell you what drive has gone bad.

[–] [email protected] 2 points 5 months ago

Of course, Gentoo with mdadm! I am running Linux software raid for the last... 20 years? And never had a single issue.

Also a big Gentoo fan, and of course use podman instead of docker :)

[–] [email protected] 2 points 5 months ago

I was in a similar boat. Initially, I ran debian with docker but later on decided to check out unraid. It's pretty easy to get setup, and you have a lot of docker containers pre-configured, so you can just click and install. I have it notify me whenever something goes on with it, but outside of that, I don't tinker much with it.

Only two weird things about it though...

  1. You dont install unraid. Instead, you run it through a usb. More specifically, the usb has a specific config that'll then load everything to your memory.

  2. Recently, they redid their pay structure so not too familiar with the changes but you do have to pay for unraid.

[–] [email protected] 2 points 5 months ago
[–] [email protected] 1 points 5 months ago (1 children)
[–] [email protected] 4 points 5 months ago (1 children)

I'm not falling for that one again. Next you'll tell me to use DeezOS

[–] [email protected] 1 points 5 months ago