Btrfs

Btrfs (B-tree FS, uitgesproken als Better FS[1][2]) is een copy-on-write-bestandssysteem ontworpen en geïmplementeerd door Oracle en uitgebracht onder de GNU General Public License (GPL). Btrfs is gemaakt als een antwoord op ZFS en de tekortkomingen van de huidige bestandssystemen.[3] Het bestandssysteem kan gebruikt worden op Linux en Windows.[4]

Limieten

  • Maximumgrootte van het bestandssysteem 16 exabyte.
  • Maximumgrootte van één enkel bestand 16 exabyte.
  • Aantal bestanden in elk individueel bestandssysteem 264.
  • Maximumgrootte van bestandsnaam 255 bytes.

Eigenschappen

Btrfs beweert een "gemakkelijk te herstellen en te onderhouden bestandssysteem te zijn, dat zich focust op fouttolerantie". Thans zijn er nog enkele basiseigenschappen die ontbreken op Btrfs, maar Btrfs is volop in ontwikkeling.

Eigenschappen:

  • Dynamische allocatie van inodes (geen maximumaantal bestanden bij het maken van het bestandssysteem)
  • Snapshots maken die beschrijfbaar zijn en snapshots maken van snapshots
  • Subvolumes
  • Object-level mirroring en striping
  • Controlesommen op data en metagegevens (voor een goede integriteit; op het moment wordt CRC-32C gebruikt, maar er zijn alternatieven gepland[5])
  • Compressie (zlib; mount optie -o compress)
  • Copy-on-write-logging voor alle data en metagegevens
  • goede samenwerking met de device mapper voor het gebruik van meerdere apparaten, met ingebouwde RAID-algoritmes
  • Online bestandssysteem en snelle offline check
  • Efficiënte incrementele back-ups en bestandssysteem-mirroring
  • Mogelijkheid tot het upgraden van ext3-bestandssysteem naar Btrfs en om terug in originele staat te herstellen[6]
  • Solid state drive (SSD)-geoptimaliseerde modus (mount optie -o ssd; geen wear levelling. Het zorgt dat gegevens niet op dezelfde plaats weggeschreven worden door middel van meerdere superblocks.[7])
  • Online defragmentatie
  • Seed-device-ondersteuning[8]

Redundantie (RAID)

Een Btrfs-bestandssysteem kan worden gemaakt boven op een groot aantal apparaten, en nog veel meer apparaten kunnen nadien worden toegevoegd. Standaard zullen alle metagegevens gemirrord worden over twee apparaten. Datagegevens worden gestriped (verdeeld) over alle aanwezige apparaten. Als er slechts één apparaat aanwezig is, zullen de metagegevens worden gedupliceerd op dat ene apparaat.

Thans ondersteunt Btrfs alleen RAID-0, RAID-1 en RAID-10. Men is bezig met het implementeren van RAID-5 en RAID-6.

Gedistribueerde systemen

Nu is Btrfs nog niet in staat om een gedistribueerd of netwerkbestandssysteem te zijn. Maar Oracle is begonnen met het ontwerpen van CRFS (Cohorent Remote File System). Dit is een netwerkbestandssysteemprotocol speciaal ontworpen voor het gebruik van netwerkopslag op een Btrfs-bestandssysteem.

Copy-on-write

Alle bewerkingen zijn copy-on-writetransacties. Hierdoor hoeft het bestandssysteem niet nagekeken te worden op fouten. Elk blok wordt nagekeken om stille datacorruptie te vermijden, de data herstelt zichzelf indien er gebruikgemaakt wordt van een replicaconfiguratie (RAID).

Snapshots

Btrfs voorziet in ongelimiteerd gebruik van snapshots. Een snapshot is een momentopname van een bestandssysteem.

Snapshots helpen in het back-up proces en in het herstelproces. Elke snapshot kan een volledige back-up genereren. De mogelijkheid bestaat ook om een incrementele back-up te genereren door verschillende snapshots samen te gebruiken. Incrementele back-ups maken het gebruik van herstel op afstand zeer efficiënt.

Concurrentie

Ext4 wordt gezien als een overgangssysteem naar Btrfs.[9]

ZFS implementeren in Linux is moeilijker omdat ZFS onder de CDDL-licentie is uitgegeven en de Linuxkernel onder GPL wordt gedistribueerd. ZFS is inmiddels wel beschikbaar via FUSE.[10]

Zie ook

Bronnen, noten en/of referenties
  • http://btrfs.wiki.kernel.org/
  • Dit artikel of een eerdere versie ervan is een (gedeeltelijke) vertaling van het artikel Btrfs op de Engelstalige Wikipedia, dat onder de licentie Creative Commons Naamsvermelding/Gelijk delen valt. Zie de bewerkingsgeschiedenis aldaar.
  • http://oss.oracle.com/projects/btrfs/

  1. Chunkfs: Fast file system check and repair. Gearchiveerd op 25 februari 2021.
  2. CRFS and POHMELFS [LWN.net]. Lwn.net. Gearchiveerd op 16 maart 2022.
  3. Valerie Aurora, A short history of btrfs.
  4. WinBtrfs 1.0 Released For Supporting Btrfs On Windows, 5 september 2017, Phoronix
  5. Wiki FAQ: What checksum function does Btrfs use?. Btrfs.wiki.kernel.org.
  6. Conversion from Ext3 - btrfs Wiki. Btrfs.wiki.kernel.org.
  7. Btrfs and Solid State Disks (SSD). Oss.oracle.com.
  8. Chris Mason, Changelog.
  9. Kernel Log: Ext4 completes development phase as interim step to btrfs. Gearchiveerd op 21 februari 2009.
  10. Linux: ZFS, Licenses and Patents. Gearchiveerd op 22 april 2007.
· · Sjabloon bewerken
Software:Application Express · Btrfs · Cloud · Database · Java (JRE) · Linux · MySQL · PL/SQL · Portal · Solaris
Overige:Hyperion · PeopleSoft · Sun Microsystems
Personen:Larry Ellison · Mark Hurd