ZFS
Siehe auch
ZFS benötigt RAM. Eine gute Regel zur Berechung ist 5 GB RAM pro TB Disk Space. Bei Verwendung von Features wie Deduplication wächst der Memory-Bedarf nochmal an. ZFS hat die Major-ID 230 zvol
.
ZFS ist kein integraler Bestandteil von RHEL, und wird daher hier als separate Software kategorisiert.
Installation
Bemerkung
DKMS (Dynamic Kernel Module Support) oder kABI? Von der Homepage des ZFS-Projekts:
DKMS packages are recommended for users running a non-distribution kernel or for users who wish to apply local customizations to OpenZFS. For most users the kABI-tracking kmod packages are recommended in order to avoid needing to rebuild OpenZFS for every kernel update.
Am Beispiel von RHEL 8 kABI-Variante installieren:
dnf -y install https://zfsonlinux.org/epel/zfs-release-2-3$(rpm --eval "%{dist}").noarch.rpm
# kABI method
dnf config-manager --disable zfs
dnf config-manager --enable zfs-kmod
dnf -y install zfs
systemctl preset zfs-import-cache zfs-import-scan zfs-mount zfs-share zfs-zed zfs.target
echo zfs > /etc/modules-load.d/zfs.conf
reboot
Unit-Test ausführen. Dieser dauert 5 Minuten. Wichtig ist am Ende die Ausgabe von „no leaks“:
ztest --vdev-file-directory= /tmp -VVV
ZFS-Pool einrichten
Für die verschiedenen Festplatten-Konzepte wie Mirror, RAID etc. siehe man zpoolconcepts
. Festplatten, die einem Pool zugeordnet sind, können nicht mehr einem anderen Pool zugeordnet werden.
Pool namens „data“ anlegen:
# raidz2 requires at least 3 devices
zpool create data raidz2 /dev/vd[b-d]
Das Verzeichnis /data
wird automatisch angelegt und ist auch nach einem Reboot verfügbar.
zpool list -v
Ausgabe:
NAME SIZE ALLOC FREE CKPOINT EXPANDSZ FRAG CAP DEDUP HEALTH ALTROOT
data 2.75G 333K 2.75G - - 0% 0% 1.00x ONLINE -
raidz2-0 2.75G 333K 2.75G - - 0% 0.01% - ONLINE
vdb 1.99G - - - - - - - ONLINE
vdc 2.99G - - - - - - - ONLINE
vdd 1014M - - - - - - - ONLINE
ZFS Cheat Sheet
Disk für das Caching definieren:
zpool add data cache /dev/nvme0n1p1
Hot Swap und Ersatz mit grösseren Platten ermöglichen:
zpool set autoreplace=on data
zpool set autoexpand=on data
Einstellungen werden an alle Unterpools weitervererbt:
zfs set compression=lz4 data
# needs massive amount of RAM
zfs set dedup=sha256 data/pictures
Pool anlegen:
zfs create data/backup/user
Zustand abfragen:
zpool list -v
zpool get all data
zpool iostat -v data
zfs get all data/backup/user
Pool auf Fehler prüfen (sehr I/O-intensiv):
# put this in a scheduler like systemd-timer
zpool scrub data
ZFS und NFS
Auf Seite des ZFS-Servers:
dnf -y install nfs-utils
systemctl enable nfs-server
systemctl start nfs-server
zfs set sharenfs="rw=@192.0.2.26/32" backup/user/linuxfabrik
Auf Client-Seite, als root:
mkdir -p /mnt/backup
mount 192.0.2.52:/backup/user/linuxfabrik /mnt/backup
Built on 2025-01-06