Difference between revisions of "ZFS"

From HackerNet
Jump to: navigation, search
Line 45: Line 45:
  
 
===SSD===
 
===SSD===
Read och write
+
Level 2 Adjustable Replacement Cache (L2ARC), är en utökning av den read cache (ARC) som finns i RAM.
 
  zpool add -f POOL cache sdf
 
  zpool add -f POOL cache sdf
 +
ZFS Intent Log (ZIL) går att likna vid journalen i ett journalförande filsystem. Synkrona skrivningar skrivs alltid till ZIL först och flushas senare till poolen vid fasta intervall. En Separate Intent Log (SLOG) i form av SSD rekommenderas för ökad prestanda vid synkrona skrivningar. ZIL är ingen write cache utan används enbart som ett skydd mot dataförlust, den enda prestandaökningen rör synkrona skrivningar som utan en SLOG hade skrivits två gånger till samma disk då ZIL befunnit sig inuti den pool dit data skrivs.
 
  zpool add -f POOL log sdg
 
  zpool add -f POOL log sdg
 +
Om man är extra rädd om sin data kan man tvinga alla skrivningar att gå genom ZIL med kommandot nedan. Det går att ställa på enskilda dataset eller hela pooler om så önskas.
 +
zfs set sync=always POOL/test
 +
Det går även att stänga av ZIL helt om man inte bryr sig om dataintegritet (samma syntax som ovan fast disable istället för always, standard är default).
  
 
===Scrub===
 
===Scrub===
 +
Scrubbing används i ZFS för att bibehålla dataintegritet och fixa eventuella fel på diskarna i din pool. Detta sker inte per automatik utan måste triggas, cronjob rekommenderas starkt.
 
  zpool scrub
 
  zpool scrub
 
''IO intensive''
 
''IO intensive''

Revision as of 19:46, 29 May 2016

ZFS är filsystem kombinerat med volymhanterare. Det körs främst på BSD men finns även till Linux.

Installation

Ubuntu

sudo apt-add-repository -y ppa:zfs-native/stable
sudo apt-get update && sudo apt-get -y install ubuntu-zfs

Fedora

sudo dnf install --nogpgcheck http://archive.zfsonlinux.org/fedora/zfs-release$(rpm -E %dist).noarch.rpm
sudo dnf install kernel-devel zfs 
sudo /sbin/modprobe zfs

Debian

su -
apt-get install lsb-release
wget http://archive.zfsonlinux.org/debian/pool/main/z/zfsonlinux/zfsonlinux_6_all.deb
dpkg -i zfsonlinux_6_all.deb
apt-get update && apt-get install debian-zfs

Konfiguration

Pool

zpool create POOL raidz1 \
        /dev/disk/by-id/ata-WDC_WD.. \
        /dev/disk/by-id/ata-WDC_WD.. \
        /dev/disk/by-id/ata-WDC_WD.. \
        -o ashift=12 -o failmode=continue

Lägg till -f om det inte finns någon EFI label.

 zfs set atime=off POOL

Show

zpool list
zpool status
zfs get all
zpool iostat -v POOL

Mount point

zfs set mountpoint=/path/pool POOL
chown -R user:user /path/pool

Dataset

zfs create POOL/test

Compression

zfs set compression=on POOL/test

Dedup

zfs set dedup=on POOL/test

SSD

Level 2 Adjustable Replacement Cache (L2ARC), är en utökning av den read cache (ARC) som finns i RAM.

zpool add -f POOL cache sdf

ZFS Intent Log (ZIL) går att likna vid journalen i ett journalförande filsystem. Synkrona skrivningar skrivs alltid till ZIL först och flushas senare till poolen vid fasta intervall. En Separate Intent Log (SLOG) i form av SSD rekommenderas för ökad prestanda vid synkrona skrivningar. ZIL är ingen write cache utan används enbart som ett skydd mot dataförlust, den enda prestandaökningen rör synkrona skrivningar som utan en SLOG hade skrivits två gånger till samma disk då ZIL befunnit sig inuti den pool dit data skrivs.

zpool add -f POOL log sdg

Om man är extra rädd om sin data kan man tvinga alla skrivningar att gå genom ZIL med kommandot nedan. Det går att ställa på enskilda dataset eller hela pooler om så önskas.

zfs set sync=always POOL/test

Det går även att stänga av ZIL helt om man inte bryr sig om dataintegritet (samma syntax som ovan fast disable istället för always, standard är default).

Scrub

Scrubbing används i ZFS för att bibehålla dataintegritet och fixa eventuella fel på diskarna i din pool. Detta sker inte per automatik utan måste triggas, cronjob rekommenderas starkt.

zpool scrub

IO intensive

Snapshots

Snapshot kan tas både på pools och datasets, varje snapshot kräver ett unikt namn.

Dataset snapshot

zfs snapshot POOL/test@NAME

Pool snapshot

zfs snapshot POOL@NAME

Lista snapshots

zfs list -t snapshot

Rollback till snapshot

zfs rollback POOL/test@NAME

Ta bort snapshot

zfs destroy POOL/test@NAME

Automatiska snapshots
Det finns ett antal olika paket/skript för att sköta automatisering av snapshots för ZFS. Här beskrivs användning av det cron-baserade zfs-auto-snapshot som skapats av ZFS on Linux-utvecklarna. Nedan följer ett antal kommandon för justering av frekvens och historik:

zfs set com.sun:auto-snapshot=true POOL/test Enable/disable av automatiska snapshots på ett dataset.

zfs set com.sun:auto-snapshot:monthly=false POOL/test Enable/disable av månatliga snapshots, som mest bevaras tolv snapshots.

zfs set com.sun:auto-snapshot:weekly=false POOL/test Enable/disable av veckovisa snapshots, som mest bevaras åtta snapshots.

zfs set com.sun:auto-snapshot:daily=true POOL/test Enable/disable av dagliga snapshots, som mest bevaras 31 snapshots.

zfs set com.sun:auto-snapshot:hourly=false POOL/test Enable/disable av snapshots varje timme, som mest bevaras 24 snapshots.

zfs set com.sun:auto-snapshot:frequent=false POOL/test Enable/disable av snapshots varje kvart, som mest bevaras fyra snapshots.

För att ändra t ex antal sparade snapshots får man editera de medföljande cron-jobb som installeras tillsammans med zfs-auto-snapshot. Växeln som används för att ställa just detta är --keep=X.