-
-
Notifications
You must be signed in to change notification settings - Fork 6
ZFS FAQ
How do I remount a filesystem in read/write mode? zfs set readonly=off zroot
How do I mount all filesystems? zfs mount -a
What can cause some filesystems not to mount at startup?
There are a few possibilities.
- canmount=off property is set on the filesystem
- The parent directory has an empty folder in it. e.g. tank/foo/bar where tank/foo/ has a folder called bar in it when tank/foo is mouunted. This would block tank/foo/bar to mount.
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
zfs set sharenfs="-maproot=0 -network 192.168.0.0/24" zroot/my/path
service mountd restart
zfs get sharenfs zroot/my/path
Note that any entries from sharenfs commands get placed in /etc/zfs/exports
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
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.
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
Setting a larger recordsize can be quite beneficial for large files such as videos.
zfs set recordsize=1M tank/media/video
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.
Good for frequent small file writes.
Be sure to mirror it. Don't use QLC SSDs.
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.
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