Hi there,
I’m not an expert in ZFS (I know enough to be a dangerous fanboy, haha), but I have an unraid server with two ZFS pools: one with HDDs and one with SSDs.
I recently bought a new 4TB Samsung 990 Pro SSD and want to add it to the SSD pool.
My initial thought was to add the 990 to the pool as a new VDEV. However, I’m also considering recreating the SSD pool with two drives in a strip configuration. I don’t mind disk failures because I regularly snapshot and back up the SSD pool to the HDD pool.
The main goal is to have access to all 5TB of storage.
I’m wondering if it’s a good idea to combine these drives into one pool or if it would be better to create three separate pools.
Stripes and mirrors have similar read performance. Write performance will suffer in a mirror, though, so it depends on your use case. Personally I’d go with mirrors, or best of both worlds, mirrors + stripes. Restoring backups and outages are a pain. Of course this halves your storage space, but drives are comparatively cheap. You’re better off doing something silly like bridging the drives with mergerfs. And no matter what without mirroring or RAID-Z you’re giving up on ZFS best feature- the check-summing based healing. Better off just yoloing with ext4.
Hard drives and SSDs should always exist in separate pools, unless you’re using the SSD as a pool cache for read or write, but realistically outside massive databases or busy virtual machine storage almost no one needs write caching.
The main reason for separating them is that you’ll get consistent performance from the pool with like hardware, otherwise your performance for reading from the pool will be equivalent to the performance of the slowest drive in the pool.
Thanks for your perspective.
I decided to go with the new vdev because:
I did this via:
zpool add ssdPool /dev/disk/by-id/nvme-Samsung_SSD_990_PRO_4TB-part3
I don’t like ext4 because it is not easily backupable (it doesn’t have snapshots, which are moved periodically to hddPool).