Skip to content

ZFS FAQ

Lucas Holt edited this page Jan 16, 2024 · 14 revisions

How do I remount a filesystem in read/write mode? zfs set readonly=off zroot

How do I mount all filesystems? zfs mount -a

Recovering EFI boot partition

If your boot loader gets corrupted, you can boot off of MidnightBSD install media for your release and do the following from the live cd functionality.

(replace nvd0 with your disk. EFI should be on the first partition)

(more destructive, can wipe custom configurations here) gpart bootcode -p /boot/boot1.efifat -i 1 nvd0

In some cases, you can simply copy the loader.efi (after mounting it) mount_msdosfs /dev/nvd0p1 /mnt cp /boot/loader.efi /mnt/efi/boot/BOOTx64.efi

NFS

Setup NFS shares

zfs set sharenfs="-maproot=0 -network 192.168.0.0/24" zroot/my/path

service mountd restart

Verify configuration

zfs get sharenfs zroot/my/path

Note that any entries from sharenfs commands get placed in /etc/zfs/exports

Setting up multiple subnets

note the new lines INSIDE the quotes

zfs set sharenfs="-maproot=root -network 10.0.0.0/24 
> /path/to/mountpoint -maproot=root -network 192.168.0.0/24 
> /path/to/mountpoint -maproot=root -network 172.16.0.0/24" pool0/space

Setup a ZFS mirror on existing zfs root

See this page https://dan.langille.org/2019/10/15/creating-a-mirror-from-your-zroot/

Effectively, you need to replicate the partition table using gpart backup / restore, add the zfs partition to the pool, and set it up as bootable either with the mnbsd-boot partition or the efi partition (assumes gpt) as necessary.

MidnightBSD partition types are mnbsd-boot and mnbsd-zfs on GPT.

Tuning

Tuning for PostgreSQL

many guides recommend 8K or 16K for recordsize with postgresql. There are some benchmarks showing better results with 16K, but most favor 8k as that aligns with default block sizes in PG.

zfs set recordsize=8K tank/usr/local/pgsql

zfs set primarycache=metadata  tank/usr/local/pgsql

zfs set logbias=throughput  tank/usr/local/pgsql

zfs set redundant_metadata=most  tank/usr/local/pgsql

Tuning for large files

Setting a larger recordsize can be quite beneficial for large files such as videos.

zfs set recordsize=1M tank/media/video

Tuning for Virtual Machine storage

For Virtual machines, it's important to write data reliably to prevent damage during power off or panics. (e.g. with bhyve VMs) Set the sync property on the file system in question.

zfs set sync=always tank/filesystem

A zil slog will not help much with this configuration. Further, it's important to make sure that there is a lot of free space in your pool to improve write performance. You're better off with a much larger, slow disk than a fast small one for writing large files like VMs.

See https://www.truenas.com/community/threads/the-path-to-success-for-block-storage.81165/

Additionally, using primarycache=metadata property can help with performance, but only if the zfs blocksize matches what the VM is using. Otherwise, there can be a performance penalty due to alignment issues and writes.

When to use SLOG

Good for frequent small file writes.

Be sure to mirror it. Don't use QLC SSDs.

See https://klarasystems.com/articles/what-makes-a-good-time-to-use-openzfs-slog-and-when-should-you-avoid-it/

Deduplication

It's usually a bad idea to use deduplication unless you have a lot of RAM or a very small file system. The minimum is usually around 5GB of RAM per 1TB of disk.

ZFS send / receive

To receive data as a non root user, myuser:

zfs allow myuser mount,create,receive vm/vm

To send, first snapshot then send

zfs snapshot vm/vm/m3164b@luke
zfs send vm/vm/m3164b@luke | ssh myuser@myhost zfs recv vm/vm/m3164