Ich verwende ZFS unter Linux als Volume-Manager und als Mittel, um herkömmlichen Dateisystemen zusätzlichen Schutz und zusätzliche Funktionen zu bieten. Dies umfasst das Bringen von Snapshots, Replikation, Deduplizierung, Komprimierung und erweitertem Caching auf Blockebene in die XFS- oder ext4-Dateisysteme.
Weitere Erklärungen finden Sie unter: https://pthree.org/2012/12/21/zfs-administration-part-xiv-zvols/ .
In meinem häufigsten Anwendungsfall nutze ich die zvol-Funktion von ZFS, um ein spärliches Volume in einem vorhandenen zpool zu erstellen. Die Eigenschaften dieses ZVOL können genau wie die eines normalen ZFS-Dateisystems festgelegt werden. An dieser Stelle können Sie Eigenschaften wie Komprimierungstyp, Volume-Größe, Caching-Methode usw. festlegen.
Wenn Sie dieses zvol erstellen, wird Linux ein Block-Gerät angezeigt, das mit dem Dateisystem Ihrer Wahl formatiert werden kann. Verwenden Sie fdisk
oder parted
, um Ihre Partition und mkfs
das fertige Volume zu erstellen .
Hängen Sie dies ein und Sie haben im Wesentlichen ein Dateisystem, das von einem zvol mit all seinen Eigenschaften unterstützt wird.
Hier ist mein Workflow ...
Erstellen Sie einen Zpool, der aus vier Datenträgern besteht:
Sie möchten die ashift=12
Direktive für den Typ von Datenträgern, den Sie verwenden. Der zpool-Name ist in diesem Fall "vol0".
zpool create -o ashift = 12 -f vol0 mirror
Festlegen der anfänglichen Zpool-Einstellungen:
Ich autoexpand=on
stelle die Zpool-Ebene ein, falls ich jemals die Festplatten durch größere Laufwerke ersetzen oder den Pool in einem ZFS-Spiegelsetup erweitern möchte. Normalerweise verwende ich ZFS raidz1 / 2/3 nicht, weil die Leistung schlecht ist und der Zpool nicht erweitert werden kann.
zpool set autoexpand=on vol0
Festlegen der anfänglichen Eigenschaften
des ZFS- Dateisystems: Verwenden Sie den lz4
Komprimierungsalgorithmus für neue ZFS-Installationen. Es ist in Ordnung, es die ganze Zeit eingeschaltet zu lassen.
zfs set compression=lz4 vol0
zfs set atime=off vol0
ZFS erstellen zvol:
Für ZFS unter Linux ist es sehr wichtig, dass Sie eine große Blockgröße verwenden. -o volblocksize=128k
ist hier unbedingt erforderlich. Die -s
Option erstellt ein spärliches zvol und belegt erst dann Speicherplatz im Pool, wenn er benötigt wird. Sie können hier ein Overcommit durchführen, wenn Sie Ihre Daten gut kennen. In diesem Fall habe ich ungefähr 444 GB nutzbaren Speicherplatz im Pool, aber ich präsentiere XFS ein 800 GB-Volume.
zfs create -o volblocksize=128K -s -V 800G vol0/pprovol
Partition zvol device:
( sollte / dev / zd0 für das erste zvol sein; / dev / zd16, / dev / zd32 usw. für nachfolgende zvols )
fdisk /dev/zd0 # (create new aligned partition with the "c" and "u" parameters)
Erstellen Sie das Dateisystem:
mkfs.xfs oder ext4 und hängen Sie es in die neu erstellte Partition / dev / zd0p1 ein.
mkfs.xfs -f -l size=256m,version=2 -s size=4096 /dev/zd0p1
Nimm die UUID mit blkid
und ändere sie /etc/fstab
.
UUID=455cae52-89e0-4fb3-a896-8f597a1ea402 /ppro xfs noatime,logbufs=8,logbsize=256k 1 2
Hängen Sie das neue Dateisystem ein.
mount /ppro/
Ergebnisse...
[root@Testa ~]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/sde2 20G 8.9G 9.9G 48% /
tmpfs 32G 0 32G 0% /dev/shm
/dev/sde1 485M 63M 397M 14% /boot
/dev/sde7 2.0G 68M 1.9G 4% /tmp
/dev/sde3 12G 2.6G 8.7G 24% /usr
/dev/sde6 6.0G 907M 4.8G 16% /var
/dev/zd0p1 800G 398G 403G 50% /ppro <-- Compressed ZFS-backed XFS filesystem.
vol0 110G 256K 110G 1% /vol0
Auflistung des ZFS-Dateisystems.
[root@Testa ~]# zfs list
NAME USED AVAIL REFER MOUNTPOINT
vol0 328G 109G 272K /vol0
vol0/pprovol 326G 109G 186G - <-- The actual zvol providing the backing for XFS.
vol1 183G 817G 136K /vol1
vol1/images 183G 817G 183G /images
ZFS-Zpool-Liste.
[root@Testa ~]# zpool list -v
NAME SIZE ALLOC FREE CAP DEDUP HEALTH ALTROOT
vol0 444G 328G 116G 73% 1.00x ONLINE -
mirror 222G 164G 58.1G -
scsi-AccOW140403AS1322043 - - - -
scsi-AccOW140403AS1322042 - - - -
mirror 222G 164G 58.1G -
scsi-AccOW140403AS1322013 - - - -
scsi-AccOW140403AS1322044 - - - -
ZFS-ZVOL-Eigenschaften ( beachten Sie referenced
, compressratio
undvolsize
).
[root@Testa ~]# zfs get all vol0/pprovol
NAME PROPERTY VALUE SOURCE
vol0/pprovol type volume -
vol0/pprovol creation Sun May 11 15:27 2014 -
vol0/pprovol used 326G -
vol0/pprovol available 109G -
vol0/pprovol referenced 186G -
vol0/pprovol compressratio 2.99x -
vol0/pprovol reservation none default
vol0/pprovol volsize 800G local
vol0/pprovol volblocksize 128K -
vol0/pprovol checksum on default
vol0/pprovol compression lz4 inherited from vol0
vol0/pprovol readonly off default
vol0/pprovol copies 1 default
vol0/pprovol refreservation none default
vol0/pprovol primarycache all default
vol0/pprovol secondarycache all default
vol0/pprovol usedbysnapshots 140G -
vol0/pprovol usedbydataset 186G -
vol0/pprovol usedbychildren 0 -
vol0/pprovol usedbyrefreservation 0 -
vol0/pprovol logbias latency default
vol0/pprovol dedup off default
vol0/pprovol mlslabel none default
vol0/pprovol sync standard default
vol0/pprovol refcompressratio 3.32x -
vol0/pprovol written 210M -
vol0/pprovol snapdev hidden default