ZFS

Kokeneet kirjoittajat eivät ole vielä tarkistaneet sivun nykyistä versiota, ja se voi poiketa merkittävästi 25. heinäkuuta 2021 tarkistetusta versiosta . tarkastukset vaativat 10 muokkausta .
ZFS
Kehittäjä Oracle (entinen Sun Microsystems ) , OpenZFS-
Tiedostojärjestelmä ZFS - Zettabyte-tiedostojärjestelmä
Jättöpäivämäärä marraskuuta 2005 ( OpenSolaris )
Rakenne
Kansion sisältö Laajennettava hash-taulukko
Rajoitukset
Tiedoston enimmäiskoko 16  exbitavua
Tiedostojen enimmäismäärä 248 _
Tiedostonimen enimmäispituus 255 tavua
Suurin äänenvoimakkuuden koko 256  sebitavua
Otsikoissa kelvollisia merkkejä ei koodausta tai UTF-8 (valinnainen)
Ominaisuudet
Päivämäärän tallennustarkkuus 1 ns [1]
Metatietovirrat Kyllä (nimeltään Extended Attributes )
Attribuutit POSIX , lisä
Käyttöoikeudet POSIX
Taustan pakkaus Joo
Taustasalaus Pool-versiosta 30
OS tuettu Solaris , OpenSolaris , FreeBSD , Linux ( FUSE :n tai erillisen ydinmoduulin kautta ( ZFS Linuxissa )), Apple Mac OS X 10.5 , Windows ( ZFSin )

ZFS (Zettabyte File System) on Merkle - puun kopiointi-kirjoitustiedostojärjestelmä , jonka Sun Microsystems loi vuosina 2004–2005 Solaris - käyttöjärjestelmää varten . Tämä tiedostojärjestelmä tukee suuria tietomääriä, yhdistää käsitteet tiedostojärjestelmästä, RAID -taulukoista, loogisesta levyn (volyymi) hallinnasta , kevyiden tiedostojärjestelmien periaatteesta ja tarjoaa yksinkertaisen tiedontallennusmäärien hallinnan. Kun ZFS luotiin, sen tietojen asettelurakenne oli innovatiivinen. On olemassa avoimia ZFS-toteutuksia , erityisesti OpenZFS on lisensoitu CDDL-lisenssillä ( Common Development and Distribution License ). Lisenssirajoitusten vuoksi ZFS-tuki GNU/Linuxissa on rajoitettu, mikä ei päde ZFS:n kaltaiseen Btrfs -tiedostojärjestelmään . ZFS:ää kehitetään parhaillaan aktiivisesti.  

ZFS:n tärkeimmät edut ovat sen täydellinen fyysisten tietovälineiden ja loogisten taltioiden hallinta sekä tiedostojärjestelmän johdonmukaisuuden jatkuva ylläpito. Tiedonabstrahoinnin eri tasoilla toimiva ZFS pystyy tarjoamaan nopean pääsyn niihin, hallitsemaan niiden eheyttä ja minimoimaan tietojen pirstoutumisen . ZFS on erittäin konfiguroitavissa, sen avulla voit muuttaa prosessissa olevan levytilan määrää ja asettaa erikokoisia tietolohkoja eri sovelluksille ja tarjoaa rinnakkaisia ​​luku- ja kirjoitustoimintoja.

Historia

ZFS:n suunnitteli ja rakensi Sun Microsystemsissä Jeff Bonwickin johtama tiimi, ja se julkistettiin  14. syyskuuta 2004 [2] . Lopullisen julkaisun lähdekoodi integroitiin Solariksen päähaaraan 31. lokakuuta 2005 [3] .

ZFS sisällytettiin OpenSolaris -versioon 27 , joka julkaistiin 16. marraskuuta 2005. Sun ilmoitti, että ZFS integroitiin Solaris 10:n 6/06 päivitykseen kesäkuussa 2006, vuosi OpenSolaris - yhteisön avaamisen jälkeen [4] .

ZFS:n nimi oli alun perin " Zettabyte File System", mutta myöhemmin nimi muuttui yksinkertaiseksi lyhenteeksi [5] .

ZFS julkaistiin kaupallisella lisenssillä osana Solaris-käyttöjärjestelmää, sitten SUN Microsystemsin avoimen lähdekoodin ZFS OpenSolaris-projektissa CDDL:n alla. Oraclen SUN Microsystemsin hankinnan jälkeen koodi suljettiin uudelleen, mutta siihen mennessä ZFS oli jo mukana FreeBSD:ssä ja muissa avoimen lähdekoodin projekteissa, jotka kehittivät itsenäisesti ja vaihtoivat lähdekoodeja "backporttien" ( eng.  backports ) kautta [6] .

Vuonna 2013 käynnistettiin OpenZFS- projekti [7] [8] , joka ottaa Illumosilta uusia ominaisuuksia ja korjauksia ja jakaa kaikkiin portteihin muille alustoille ja päinvastoin [9] .

Spesifisyys

Maksimimahdollisuudet

ZFS - 128-bittinen[10] tiedostojärjestelmä, jonka avulla se voi tallentaa 18,4 × 10 18 kertaa enemmän tietoa kuin kaikki tunnetut 64-bittiset järjestelmät. ZFS on suunniteltu niin, että sen rajoitukset ovat niin mahdottomia saavuttaa, että niitä ei tule kohdata käytännössä lähitulevaisuudessa [11] .

Jotkut ZFS:n teoreettiset rajoitukset:

Samanaikaisesti tiedostojärjestelmän hallintaohjelmat asettavat lisärajoituksia.

Tallennusvarastot

Toisin kuin perinteiset tiedostojärjestelmät, jotka sijaitsevat yhdessä laitteessa ja vaativat näin ollen volyymin hallinnan, kun niitä käytetään useammassa kuin yhdessä laitteessa, ZFS on rakennettu zpooleiksi kutsuttujen virtuaalisten tallennuspoolien päälle . Pooli on rakennettu virtuaalilaitteista ( vdevs ), joista jokainen on joko fyysinen laite tai yhden tai useamman laitteen peili ( RAID 1) tai ( RAID Z) kahden tai useamman laitteen ryhmä. Kaikkien vdevien kapasiteetti on sitten kaikkien zpoolin tiedostojärjestelmien käytettävissä .

Kiintiö voidaan asettaa rajoittamaan tietylle tiedostojärjestelmälle tai taltiolle käytettävissä olevaa tilaa . Lisäksi on mahdollista käyttää levyvarausta (limiittiä) - tämä varmistaa, että tietylle tiedostojärjestelmälle tai taltiolle on aina vapaata tilaa.

ZFS Pool -versiot

ZFS-tiedostojärjestelmästä ja ZFS-varannosta ( zpool ) on erilaisia ​​versioita, ja erilaisia ​​toimintoja on saatavana versiosta riippuen. Marraskuussa 2012 ZFS-poolista on 34 versiota. Kaikki poolin versiot on alun perin julkaistu Solarisille .

Versio 2 sisälsi tuen replikoiduille metatiedoille ( sama lohkot ) .  ZFS-levymuodon puurakenteesta johtuen poolin metatiedoissa olevat korjaamattomat virheet voivat johtaa siihen, että poolia ei voida avata. Tämä ominaisuus tarjoaa automaattisen metatietojen replikoinnin (jopa kolme kopiota kustakin lohkosta ) riippumatta taustalla olevasta poolin laajuisesta redundanssista . Esimerkiksi poolissa, jossa on yksi peili, kriittisimmät metatiedot kirjoitetaan kolme kertaa peilin kummallekin puolelle, yhteensä kuusi kopiota. Tämä varmistaa, että jos tiedot katoavat korruption vuoksi, kaikki poolin tiedot ovat paikannettavissa ja pooli on kunnossa.  

Versio 3 sisältää tuen hot varaosille ja kaksoispariteetti RAID-Z (raidz2); versio 4 esitteli tuen ZFS-poolin historian ylläpitämiselle ( zpool history); versio 5 lisäsi tuen lennossa tapahtuvalle pakkaamiselle ZFS-tietojoukoille gzip -menetelmällä ; versio 6 sisältää bootfs- ominaisuuden tuen (voit vaihtaa käynnistyskäyttöjärjestelmän pääkäyttäjän FS:n attribuutin avulla käynnistyslatainvaihtoehdon lisäksi).

Versio 7 esitteli tuen "kohdelokille" ( ZFS Intent Log , ZIL , lit. "intent log"), joka tarjoaa sovelluksille mahdollisuuden tietää, että niiden muokkaamat tiedot ovat vakaassa tallennustilassa järjestelmäkutsun jälkeen. . Kohdeloki pitää kirjaa näistä järjestelmäkutsuista, ne toistetaan uudelleen, jos tapahtui virtakatkos tai kriittinen virhe, jossa pääpooli ei kuitannut niiden suorittamista. Kun kohdekansio on päävarannon ulkopuolella, se varaa lohkot, jotka ketjuttavat poolin läpi.

Versiossa 8 on otettu käyttöön mahdollisuus delegoida ZFS:n hallintaan liittyviä hallinnollisia tehtäviä tavallisille käyttäjille; sitä ennen vain järjestelmänvalvojat pystyivät hallitsemaan ZFS:ää.

Versiossa 9 on olemassa olevien kiintiö- ja varaustoimintojen lisäksi lisätty kiintiöiden ja varausten määrittäminen, joka ei sisällä sisäkkäisten tietorakenteiden, kuten kloonien ja kiintiöiden ( zfs set refquota, zfs set refreservation) aiheuttamaa levytilan käyttöä. Varaus muodostetaan automaattisesti, kun luotu ei-harva ( ei-harva ) ZFS-taltio vastaa osion kokoa. Myös versiossa 9 on lisätty tuki CIFS -palvelimelle.

Versio 10 esitteli mahdollisuuden lisätä laitteita pooliin välimuistilaitteina lisävälimuistin muodostamiseksi päämuistin ja levyn välille. Välimuistilaitteiden käyttö parantaa merkittävästi suorituskykyä epäjärjestyn, enimmäkseen staattisen sisällön raskaassa lukemisessa. Versiossa 12 snapshot-ominaisuuksien tuki ilmestyi, versiossa 13 seuraavat tilannekuvaominaisuudet tulivat saataville: usedbysnapshots, usedbychildren, usedbyrefreservation, usedbydataset, versiossa 14 ja ominaisuudet ovat myös saatavilla passthrough-x, aclinheritversiossa 15 ominaisuudet userused, groupused, userquota, sisältyvät groupquota.

Versio 17 esitteli tuen kolminkertaiselle pariteetti RAID-Z :lle. Versio 18 tukee ZFS snapshot holds - ominaisuutta . Versiosta 19 alkaen tuli mahdolliseksi irrottaa liitetty laite lokien tallentamista varten, aiemmin tällaista laitetta ei voitu poistaa. Versio 20 sisältää zle - pakkausalgoritmin .

Versio 21 ottaa käyttöön duplikoinnin (yleensä zle:n käyttö). Versiosta 30 alkaen tuetaan tiedostojärjestelmän salausta , versiosta 32 alkaen tuetaan 1 Mt:n lohkoa ja versiossa 34 toteutetaan tiedostojärjestelmien välisten periytyvien verkkoosuuksien luominen.

Versio 37 lisäsi tuen lz4 -pakkausalgoritmille (tehokkaampi ja nopeampi kuin nykyiset).

Tapahtumamalli, jossa käytetään kopiointia kirjoittamista

ZFS käyttää kopiointi-kirjoitusmekanismiin perustuvaa objektitapahtumamallia . Kaikki osoittimet tiedostojärjestelmän lohkoihin sisältävät kohdelohkossa 256-bittisen tarkistussumman , joka tarkistetaan lohkoa luettaessa. Tarkistussummana voidaan käyttää joko Fletcher-summaa tai SHA-256: n kryptografista hajautusfunktiota . [13] Tiedoille voidaan valita muita tarkistussummia. Aktiivista (tällä hetkellä) dataa sisältäviä tietolohkoja ei koskaan korvata yhdessä; päinvastoin, uusi lohko allokoidaan, siihen kirjoitetaan muuttunut data ja sitten siihen viittaavien lohkojen metatiedot, jolloin kaikki allokoidaan ja kirjoitetaan uudelleen. Ylimääräisten kustannusten vähentämiseksi tämä prosessi ryhmittelee useita päivityksiä tapahtumaryhmään ja kirjaa tarvittaessa synkronisten kirjoitusten käytön.

ZFS-pooli ylläpitää lokia poolin tietojen viimeisistä muutamasta kymmenestä versiosta (viimeisiltä minuuteilta, tunneilta tai päiviltä riippuen tietojen muutoksen intensiteetistä), joka on suunniteltu palauttamaan tiedot, jos järjestelmävirhe on aiheuttanut yhdistyvät käyttökelvottomaan, parantumattomaan tilaan. Kopioinnin yhteydessä kaikki nämä lokin tietojen versiot ovat itsenäisiä, mutta niillä on yhteinen tieto.

Tilannekuvat ja kloonit

ZFS:n kopiointi-kirjoitusmallilla on toinen voimakas etu: kun ZFS kirjoittaa uutta tietoa - sen sijaan, että se vapauttaisi vanhaa dataa sisältäviä lohkoja - se voi tallentaa ne luomalla tilannekuvia tiedostojärjestelmästä. Tilannekuvat ZFS:ssä luodaan erittäin nopeasti (poikkeuksena harvoja tapauksia, joissa pitkä pooli estää FS:n aikaa vievän toiminnon), koska kaikki tilannevedoksen tiedot on jo tallennettu. ne ovat myös tilaa säästäviä, koska kaikki muuttumattomat tiedot jaetaan (jaetaan) tiedostojärjestelmän ja sen tilannevedoksen välillä.

Myös kirjoitettava tilannekuva ("klooni") voidaan luoda mistä tahansa tilannevedosta, mikä johtaa kahteen tai useampaan itsenäiseen tiedostojärjestelmään tai taltioon, jotka jakavat lohkokompleksin, mikä vähentää kokonaisjalanjälkeä ja lyhentää kloonin luontiaikaa. Heti kun muutoksia tehdään mihin tahansa tiedostojärjestelmän klooniin, sille luodaan lohkoja uusista tiedoista ja vanhat tiedot säilyvät kaikissa muissa klooneissa.

Kun klooni luodaan, se linkitetään tilannekuvaan, josta se luotiin. Tätä tilannekuvaa ei voi tuhota, jos vähintään kaksi kloonia viittaa siihen (mukaan lukien alkuperäinen tallennustila). Tämän linkin poistamiseksi tallennustila (tiedostojärjestelmä tai taltio) on luotava uudelleen, mutta tämä on helppo tehdä siirrolla, ja voit välttää ylimääräisen tilan viemisen poolissa, jos otat päällekkäisyyden poiston siirron aikana ja siirrät tallennustilan sama uima-allas.

Tilannevedosten avulla voit käyttää tietoja, jotka olivat varastossa tilannevedoksen ottamisen aikaan samana vain luku -varastona riippumatta alkuperäisestä varastosta, sen klooneista ja muista tilannekuvista. Niiden avulla voit myös palauttaa tallennustiedot nopeasti ja tarkasti tilannekuva-tilaan.

Tilannekuvia ja klooneja voidaan luoda rekursiivisesti tiedostojärjestelmäpuulle. Tämä välttää tarpeen toistaa komentoja ja hallita tapahtumia itse, koska rekursiivinen tilannekuvan luominen on ydintä.

Tilannekuvien ja kloonien (sekä uusien tiedostojärjestelmien) luominen voi olla vaikeaa ZFS:n rajoitusten vuoksi. Tilannekuvia ja klooneja ei voida luoda, jos niistä vähintään yhden nimi ylittää rajan (ja tilannevedoksen koko nimi on vähintään 2 merkkiä pidempi kuin alkuperäisen koko nimi), jos on nimiristiriita (olennainen rekursiivista tilannekuvan luomista varten), jos uudet kiintiöt ylittyvät tai varaukset eivät ole mahdollisia (kiintiöt ja varaukset peritään alkuperäisestä).

Tilannekuvien perusteella toteutetaan lisätallennusvarmuuskopiot. Tilannekuvan edelleenlähetyksen avulla voit luoda saman tilannevedossarjan uudelleen missä tahansa ZFS-varannossa. Kun uudet tilannevedokset on luotu alkuperäisestä, asteittainen tilannevedossiirto luo samat päivitetyt tiedot uudelleen kopioon tai kloonaukseen, ellei päivitysristiriita ole. Tilannekuvat kertovat myös, mitä tiedostoja on muokattu, luotu, poistettu ja nimetty uudelleen tilannekuvien välillä.

Dynaaminen osiointi

Kaikkien laitteiden dynaaminen osiointi suurimmalla suorituskyvyllä tarkoittaa, että lisälaitteet sisällytetään zpooliin, laajemmat kanavat laajenevat automaattisesti sisältämään kaikkien poolin levyjen käytön, mikä tasapainottaa kirjoituskuormitusta.

Eri lohkokoot

ZFS käyttää muuttuvaa lohkokokoa, joka on enintään 1 megatavu (poolversiosta 32 alkaen se oli aiemmin jopa 128 kilotavua). Tällä hetkellä järjestelmänvalvoja voi asettaa käytettävän lohkon enimmäiskoon, mutta osa työstä epäonnistuu (tai epäonnistuu), jos käytetään liian suuria lohkoja. Automaattiset suorituskykyasetukset vastaavat oikeuksia.

Jos pakkaus on käytössä, käytetään muuttuvia lohkokokoja. Jos lohko on pakattu, se voi sulautua pienemmäksi lohkoksi, mikä tarkoittaa, että levytilaa käytetään vähemmän ja suoritusteho (Input/Output) kasvaa (kustannushintaan lisääntynyt prosessorin ja RAM-muistin käyttö pakkaus- ja purkutoimintoihin).

ZFS-pooli tukee myös erilaisia ​​laitesektorikokoja ja valitsee automaattisesti suurimman lohkokoon poolin luomisen yhteydessä määritetyistä laitteista (sen jälkeen poolilohkon kokoa ei voi muuttaa). 512 tavun ja 4 KiB:n (4K) kokoja tuetaan vakaasti. Myös suuria lohkokokoja tuetaan, mutta käyttöjärjestelmä ei välttämättä toimi vakaasti.

Päästä päähän -tietojen eheyden valvonta

Päästä päähän -eheyden hallinta tarkoittaa tarkistussumman kirjoittamista levylle kullekin tietolohkolle, ja tarkistussumma ja tiedot on sijoitettu erityisesti mahdollisimman kauas toisistaan ​​niiden nivelvaurioiden todennäköisyyden vähentämiseksi. Jos poolissa on useita laitteita, toisessa niistä oleville tiedoille kirjoitetaan tarkistussumma toiseen. Tarkistussummia ei lasketa vain tiedoille, vaan myös metatiedoille, ja käy ilmi, että poolissa on aina tarkistussumma jokaiselle tietolohkolle.

Lukeessa mitä tahansa lohkoa, sen tarkistussumma lasketaan ja tulosta verrataan levylle tallennettuun tarkistussummaan. Poikkeavuuksien sattuessa virhe havaitaan välittömästi. Tietenkin, jos poolissa ei ole etukäteen suunniteltu redundanssia (ei RAID-Z tai muuten), niin virhettä ei voida korjata, mutta vioittunutta dataa ei esitetä todellisena.

End-to-End Data Integrityn tarkoituksena on estää havaitsematon tietojen korruptio, joka johtuu aseman tai ohjaimen laitteisto- tai laiteohjelmistovioista. Vaikka tällaisen tapahtuman todennäköisyys vaikuttaa alhaiselta, jotkut tutkimukset osoittavat, että se on varsin merkittävä kaikenkokoisille organisaatioille [14] .

Ohjelmien, jotka lukevat tai kirjoittavat tietoja, on tuettava näitä ominaisuuksia (mahdollinen tiedoston yksittäisen lohkon lukemisen epäonnistuminen, mahdollisuus, että pooli joutuu odottamaan tallennustilan palautusta, jolloin I/O roikkuu määräämättömän ajan).

Kevyen tiedostojärjestelmän luominen

ZFS:ssä tiedostojärjestelmän manipulointi poolissa on helpompaa kuin perinteisten tiedostojärjestelmien käsittelyn määrä; ZFS-tiedostojärjestelmän luomiseen tai muokkaamiseen vaadittava aika ja vaiva on enemmän kuin uuden hakemiston työmäärä kuin osion käsittely muissa teknologioissa.

Lisäominaisuudet

Muita ominaisuuksia ovat toiminto tietyn I/O-prioriteetin asettamiseen ajoitusjaksolla, tuki useille itsenäisille säikeille ennaltaehkäisevällä automaattisella pituuden ja pituuden havaitsemisella, älykäs puhdistus ja korjaus [15] , levyjen lataaminen ja jakaminen poolissa [16] , metatietojen moninkertainen toisto [17] , kopiointi-kirjoitusmekanismin tuki , mahdollisuus valita käynnistystiedostojärjestelmä käyttöjärjestelmän latausohjelmassa , asentaa pääkäynnistystiedostojärjestelmä, luoda useita juuritiedostojärjestelmiä, joista yksi (ja kaikki lapset) käytetään käyttöjärjestelmän latauksessa , kykyä integroida ohjelmistoja ja käyttöjärjestelmäpäivityksiä luomalla tilannekuvia ja klooneja tiedostojärjestelmistä, joihin ohjelmat on tallennettu, sekä näiden tilannevedosten käyttöä edellisen version ja kloonien palauttamiseen. luoda monikäynnistysjärjestelmä, jossa on mahdollisuus käynnistää erilaisia ​​kokoonpanoja tai käyttöjärjestelmäversioita ( Solaris päivitetään oletuksena), vaihtoehto tiedostonimien rajoittaminen kelvolliseen UTF-8- tekstiin valitussa normaalimuodossa, vaihtoehto, jolla tiedostonimien kirjainkoko ei ole herkkä.

Välimuistin hallinta

ZFS esittelee myös mukautuvan välimuistin korvaamisen ( ARC ), joka on uusi menetelmä välimuistin hallintaan perinteisten Solariksen muistissa olevien välimuistin virtuaalisivujen sijaan.

Mukautuva endianisuus

Matriisit ja niille konfiguroidut ZFS:t voidaan siirtää eri alustojen välillä, vaikka niillä olisikin erilainen endianness. ZFS-lohkomuoto mahdollistaa tavujen automaattisen tunnistamisen ja uudelleenjärjestämisen lennossa, kun metatietoja luetaan.

Samanaikaisesti eri järjestelmien erilainen tavujärjestys ei vaikuta sovelluksiin millään tavalla, niiden tiedostot jäävät yksinkertaiseksi tavujonoksi. Siten sovellukset ovat vastuussa itsenäisestä (alusta) muodosta jo itse tiedostoissa.

Poolin attribuutit

Pool-attribuutit ovat tapa hallita poolin ominaisuuksia ja asetuksia. Niillä on erikoistyyppejä ja kirjoitusrajoituksia. Ne osoittavat, onko pooli kirjoitettava vai luettavissa, onko tietojen duplikointi käytössä, FS oletuksena käyttöjärjestelmän lataamiseen, vaihtoehtoinen liitosjuuri, poolin ominaisuudet ja paljon muuta.

Data Store -järjestelmän ominaisuudet

Tietovarastojärjestelmän attribuutit ovat tapa hallita arkistojen ominaisuuksia ja asetuksia. Niillä on erikoistyyppejä ja kirjoitusrajoituksia. Ne määrittävät salauksen, pakkaamisen, tarkistussummien, päällekkäisyyden poistamisen, varmuuskopioinnin, välimuistin asetukset sekä tiettyjen muistien tallennuslohkojen koon. Ne osoittavat myös taltioiden koon, FS-liitospisteet, yksittäisten tallennusten saatavuuden kirjoittamista varten, varastojen kuulumisen vyöhykkeisiin, mandaatit, varaukset, kiintiöt, verkkoosuuksien automaattisen luomisen asetukset (NFS, SMB), käyttöoikeudet niihin ja lisää. Nämä attribuutit määrittävät holvien ominaisuudet. Nämä attribuutit helpottavat FS:ään liittyvien toimintojen hallintaa, jotka aiemmin suoritettiin manuaalisesti (esimerkiksi useiden lisätiedostojärjestelmien asennuksen määrittäminen, verkkoosuuksien luominen).

Osa järjestelmän attribuuteista periytyy alatason arkistojen kautta, minkä seurauksena attribuutteja sovelletaan välittömästi myös alitietovarastoihin. Ohjauspakkauksen, duplikoinnin, tietojen tarkistussummien ja vastaavien attribuutit koskevat vain äskettäin kirjoitettuja tietoja. Jotta niitä voidaan soveltaa kaikkiin tietoihin, tiedot on korvattava (tämä on helppo tehdä lähettämällä tilannekuvat samaan pooliin tallennusten uudelleenluomisen kanssa).

Data Storen mukautetut attribuutit

Jokaiselle tietovarastolle (FS, volyymi, tilannekuva jne.) voidaan määrittää mukautettuja määritteitä. Käyttäjäattribuutit eroavat järjestelmän määritteistä nimillään. Mukautetuissa määritteissä voit käyttää mitä tahansa nimeä (1–2¹⁰ tavua), mutta on suositeltavaa käyttää nimiä, jotka sisältävät kaksoispisteen (jotta vältyt ristiriitaisilta järjestelmämääritteiden kanssa), verkkotunnuksesi nimeä ennen tätä kaksoispistettä (muiden käyttäjien välttämiseksi) , määritteen nimi kaksoispisteen jälkeen. Muokatut attribuutit perivät alikaupat.

Uusien ominaisuuksien haaroittuneen kehityksen vuoksi eri käyttöjärjestelmissä useita näistä määritteistä käytetään uusina järjestelmämääritteinä.

Mukautettuja attribuutteja käyttävät käyttäjät ja erilliset ohjelmat (esimerkiksi automaattinen aikaliukusäätimen luonti- ja varmuuskopiointiohjelma).

Tiedostojärjestelmän attribuutit

Minkä tahansa tyyppisille tiedostoille voidaan määrittää useiden järjestelmäattribuuttien arvot. [18] Näiden määritteiden avulla voit hallita tiedoston toimintoja. Laajennetuilla tiedostomääritteillä on samat järjestelmäattribuutit.

Attribuuttien lisäksi, jotka tallentavat luontipäivämäärät, viimeinen käyttöoikeus, viimeinen muokkaus ja viimeinen metatietojen muokkaus, on attribuutteja [19] :

Ominaisuuden nimi Attribuutin nimi komennossa chmod[20] Tarkoitus Mitä käyttöjärjestelmä tekee tällä määritteellä
Piilotettu hidden Tällä määritteellä varustetut tiedostot eivät näy yleisessä luettelossa, jos tämä vaihtoehto on käytössä ja tuettu tiedostojen tulostusohjelmassa. Ei mitään.
harva sparse Tällä määritteellä varustettu tiedosto on suositeltavaa käsitellä harvassa, eli se sisältää nollatavuisia lohkoja, joita ei ole tallennettu asemaan, vaan oletettu. Tämä attribuutti on neuvoa-antava, eikä sillä ole mitään tekemistä sen kanssa, onko tiedosto todella harvassa. Harvatiedostojen käsittelyyn tarkoitetun tiedostonkäsittelyohjelman on edelleen saatava tietoja tiedoston harvaista lohkoista FS:stä. Ei mitään.
Järjestelmällinen system Tällä määritteellä varustettu tiedosto on tarkoitettu käyttöjärjestelmälle, se ei ole käyttäjätiedosto. Yleensä ohjelmat jättävät huomioimatta. Ei mitään.
Vain lukemista varten readonly Tällä määritteellä varustettua tiedostoa ei voi muokata (vain tietoja, ei määritteitä). Koskee kaikkia poikkeuksetta. Estää kirjoitusoikeuden, jos määrite on asetettu.
Arkistointia varten archive Tiedosto on arkistoitava. Ei mitään.
Irrotettava nounlink Hakemistoissa hakemiston nimeä ja sen välittömien alaryhmien nimiä ei voi poistaa tai muuttaa. Muut tiedostotyypit: tiedoston nimeä ei voi poistaa tai muuttaa. Estää nimen muuttamisen ja poistamisen, jos määrite on asetettu.
muuttumaton immutable Tällä määritteellä varustettua tiedostoa ei voi muuttaa (tiedot, attribuutit, paitsi itse tämä attribuutti ja viimeinen käyttöpäivä). Koskee kaikkia poikkeuksetta. Esteet muokkaavat käyttöoikeutta, jos määrite on asetettu.
Vain täydennykseksi appendonly Tiedostotietoja voidaan muokata vain lisäämällä, mutta niitä ei voi korvata. Estää kirjoitusoikeuden, jos määrite on asetettu.
Ei kaatopaikoille nodump Ei käytössä Solarisissa. Tuli BSD :ltä . Muokkaus vaatii asianmukaiset oikeudet. Ei käytössä Solarisissa.
Virustorjuntakaranteenissa av_quarantined Pääsy tiedostoon on rajoitettu, kunnes karanteeni puretaan. Attribuutti voidaan asettaa ja poistaa vain, jos sinulla on pääkäyttäjän oikeudet (viruksentorjuntaohjelmalla on ne). Estää pääsyn, jos määrite on asetettu.
Muokattu (viimeisen virustorjuntatarkistuksen jälkeen) av_modified Osoittaa, että virustorjunta ei tarkista tiedoston nykyistä versiota. Aseta automaattisesti, kun tiedosto luodaan ja aina, kun tiedoston tietoja tai kokoa muutetaan. Käyttäjä, jolla on oikeus muuttaa attribuutteja, voi asettaa. Se voidaan nollata vain, jos sinulla on pääkäyttäjän oikeudet (virustorjuntalla on ne). Asettaa attribuutin automaattisesti, kun tietoja muutetaan ja tiedosto luodaan.

Laajennetut attribuutit

Voit luoda laajennetut attribuutit jokaiselle tiedostotyypille. Laajennettu attribuutti on nimetty tavujen joukko, aivan kuten tavallinen tiedosto. Laajennetuille määritteille, kuten tavallisille tiedostoille, voidaan määrittää omat käyttöoikeudet ja järjestelmäattribuutit. Toisin kuin tavallisessa tiedostossa, laajennettuja määritteitä, kiinteitä linkkejä, ei voida luoda laajennetuille määritteille. Laajennettuja tiedostomääritteitä voidaan käsitellä normaaleina tiedostoina rajoitetusti. Tätä varten kullekin tiedostolle luodaan nimetön kansio (ensimmäisen laajennetun määritteen luomisen yhteydessä), jossa on saatavilla tämän tiedoston laajennettuja määritteitä vastaavat tavalliset tiedostot. Solariksessa tähän kansioon pääsee runat[21] -apuohjelman avulla .

Valtuuksien delegointi käyttäjille

Yksittäisten varastojen hallinta voidaan delegoida käyttäjille. Tätä varten ZFS on jakanut valtuuksia, jotka voidaan delegoida (tallennustilojen, tilannekuvien luominen, poistaminen, asennus, vertailu, edelleenlähetys ja paljon muuta). Oikeudet delegoidaan valituille varastoille samalla tavalla kuin määritteiden määrittämisessä, ja ne ulottuvat lapsivarastoihin.

Tietojen säilyttäminen ja varmuuskopiointi

Kopiointi-kirjoitusperiaatteen ansiosta ZFS :  n tiedot ovat aina johdonmukaisessa tilassa, tiedostoa ei voi kadota päällekirjoituksen yhteydessä [6] .

Käytettäessä redundanssia taltiota (RAIDZ-volyymit) tietoturva varmistetaan fyysisen mediavian varalta [6] [22] , kun taas RAIDZ on tehokas suurten tiedostojen suhteellisen pitkäkestoiseen tallentamiseen, erityisesti kun asetetaan lohkokokoa vastaavasti. tiedostot, ja toistuva uudelleenkirjoittaminen ja pienikokoisten tiedostojen sijoittaminen lisää prosessorin ja levyn alajärjestelmää [6] .

Rajoitukset

  • Solaris 10:n ZFS-toteutuksesta puuttuu läpinäkyvä salaus, kuten Solaris 11:ssä ja NTFS :ssä , vaikka se on toteutettu osana OpenSolaris-projektia [23] .
  • ZFS ei tue käyttäjä- tai ryhmäkohtaista kiintiön jakoa. Sen sijaan voit luoda nopeasti käyttäjille FS:n, joista jokaisella on oma kokonsa. Sellaisenaan ei ole olemassa käytännöllistä kiintiöratkaisua eri käyttäjien jakamille tiedostojärjestelmille (esim. kehitysryhmäprojekti), jossa tietoja voidaan jakaa käyttäjää kohti, mutta tämä voidaan toteuttaa ZFS - pinon päälle.
  • Tallennustilan laajennus saavutetaan yleensä lisäämällä levyryhmä, kuten vdev (raita, RAID-Z , RAID-Z2 tai peili ). Uudet tiedot käyttävät dynaamisesti kaikkia saatavilla olevia vdeveja. Toinen tapa lisätä levytilaa on korvata fyysiset levyt vuorotellen suuremmilla, odotettaessa jokaisen tällaisen toimenpiteen jälkeen, kunnes ZFS parantaa itsensä . Hoitoaika riippuu tallennetun tiedon määrästä , ei levyn koosta. Jos tilannekuva luodaan hoidon aikana  , tämä käynnistää hoitoprosessin uudelleen. On huomattava, että levyjen vaihtaminen ilman tietojen menetystä on mahdollista vain yhdessä poolin toimintatiloista, jotka sallivat sen.
  • Tällä hetkellä ei ole mahdollista vähentää vdevien määrää pienentämättä poolin kokoa. ZFS-kehitysryhmä työskentelee kuitenkin tämän asian parissa. Solaris 10 08/11 (päivitys 10) julkaisusta lähtien tätä ei ole vieläkään otettu käyttöön.
  • Uutta asemaa ei myöskään voi lisätä RAID-Z- tai RAID-Z2-taulukkoon (vdevs). Tämä ominaisuus on vaikea toteuttaa. Voit kuitenkin luoda RAIDZ vdev:n ja lisätä sen zpooliin .
  • Et voi sekoittaa vdev-tyyppejä zpoolissa. Jos sinulla on esimerkiksi poistettu ZFS-varasto, joka sisältää levyjä SAN -verkossa , et voi lisätä paikallisia levyjä peilattuina vdev-versioina.
  • Tietojen tallennustilan täydellinen uudelleenkonfigurointi edellyttää tietojen tallentamista ulkoiselle medialle (ZFS:n ulkopuolelle), poolien tuhoamista ja uusien poolien luomista uusien sääntöjen mukaisesti. Mutta useimmissa tapauksissa voit päästä eroon tietojen siirtämisestä vanhasta poolista uuteen ZFS:n avulla säilyttäen kaikki tai halutut tiedot ja attribuutit (tallennusta ZFS:n ulkopuolelle). Edelleenlähetys ei auta, jos salaus otetaan käyttöön tai poistetaan käytöstä, tiedostonimirajoituksia muutetaan, pakollinen pääsynhallinta poistetaan käytöstä, levylohkon kokoa muutetaan tai muita harvinaisia ​​toimintoja.
  • ZFS ei ole luonnostaan ​​klusteroitu , hajautettu tai rinnakkaistiedostojärjestelmä , eikä se tarjoa samanaikaista pääsyä tietoihin eri isännistä. ZFS on paikallinen tiedostojärjestelmä.
  • Solaris 11:n ZFS-toteutuksessa et voi muuttaa vdev-tyyppiä zpoolissa. Jos sinulla on esimerkiksi ZFS-varasto, joka sisältää levyjä (estolaitteita), et voi kopioida levyjen sisältöä tavallisiin tiedostoihin ja tuoda poolia näistä tiedostoista, etkä päinvastoin - siirtää poolia tavallisista tiedostoista levyjä.
  • Suuren tietomäärän poistaminen on hidasta estotoimintoa (pooliversiossa 37 ja sitä vanhemmissa), esimerkiksi 100 GiB:n pirstoutuneen tiedostojärjestelmän poistaminen voi kestää yli minuutin ja estää tiedostojärjestelmien luettelon ja jonkin muun tiedostojärjestelmän saamisen toiminnot samassa poolissa.
  • Poolin palautumista ei voi hallita millään tavalla sen jälkeen, kun on palautettu peilatun poolin eri kopioiden käyttöoikeus. Järjestelmä päättää itse, kuinka allas desinfioidaan , vaikka muutoksia olisi tehty itsenäisesti poolin eri kopioihin (tämä on sallittua).
  • Pahoin vaurioitunutta uima-allasta ei voida korjata, ja se on luotava uudelleen. Useissa tapauksissa käyttäjätiedot voidaan kuitenkin hakea vioittuneesta poolista tuomalla ne lukemista varten.
  • Jotkut järjestelmätiedoissa olevat parantumattomat poolin korruptiot eivät johda käyttäjätietojen vioittumiseen tai estä poolin muutoksia. Näillä vaurioilla uima-allas toimii ulkoisesti normaalisti pitkään eikä varoita korjaustarpeesta. Mutta jos se jätetään korjaamatta, se lopulta menettää käyttäjätiedot ja päätyy palautumattomaan tai jopa lukemattomaan tilaan. Mahdollisuus havaita tällaiset ongelmat ja korjata ne automaattisesti (jos mahdollista) ajoissa ei sisälly ZFS:ään ja vaatii erillisen määrityksen.

Alustat

ZFS on osa Solaris - käyttöjärjestelmää ja se on saatavilla sekä SPARC - että x86 - alustoille . Koska ZFS-koodi on avoimen lähdekoodin (CDDL-lisenssi), portit muihin käyttöjärjestelmiin ja alustoihin voidaan tuottaa ilman Oraclen osallistumista.

OpenSolaris

OpenSolaris 2008.05 käyttää ZFS:ää oletustiedostojärjestelmänä.

Nexenta OS

Nexenta OS  on käyttöjärjestelmä, jossa on GNU -ympäristö, joka on rakennettu OpenSolaris-ytimen ja sen ajonaikaisen ympäristön päälle. ZFS-tuki sisällytettiin ytimen alfa1-versioon. Äskettäin Nexenta Systems esitteli NexentaStorin  , ZFS-yhteensopivan verkkotallennusjärjestelmän, joka tarjoaa NAS / SAN / iSCSI -ominaisuudet ja perustuu Nexenta OS:ään. NexentaStor sisältää graafisen käyttöliittymän, joka yksinkertaistaa ZFS:n käyttöä. NexentaStor 1.1 julkaistiin 2. joulukuuta 2008. Se päivitti OpenSolaris-ytimen, paransi integraatiota CIFS/AD:n kanssa, lisäsi useita laajennuksia ja korjasi joitain virheitä. NexentaStorista on kaksi versiota: kaupallinen Enterprise Edition ja ilmainen Community Edition, jonka tallennuskapasiteetti on enintään 18 Tt. Elokuusta 2012 lähtien nykyinen ohjelmistoversio on 3.1.3.

Linux

Ytimen taso

CDDL-lisenssirajoitusten vuoksi ZFS ei sisälly ytimeen, mutta se on saatavana ydinmoduulina, joka on nyt saatavilla monissa GNU/Linux-jakeluissa [6] [24] .

Pitkään Linuxissa ZFS:n siirtämistä ydintasolle pidettiin juridisesti mahdottomaksi, koska CDDL -lisenssit , joiden lainkäyttövallan alaisuudessa ZFS on, ja GNU GPL , jonka lainkäyttövaltaan Linux kuuluu, eivät olleet yhteensopivia . Toukokuussa 2010 Brian Behlendorf kuitenkin esitteli uuden version projektista, joka työskentelee Linuxin ZFS-tiedostojärjestelmän alkuperäisen tuen toteuttamisessa. Lisenssirajoituksen kiertämiseksi Behlendorf päätti jakaa koko tuotteensa CDDL-lisenssin alaisena erikseen ladattavana moduulina, joka toimitetaan erillään ytimestä [25] [26] . Maaliskuusta 2013 lähtien (versio 0.6.1) hankkeen katsotaan olevan valmis teollisuuskäyttöön [24] . Ubuntu 16.04 (64-bittinen) on ensimmäinen valtavirran Linux-jakelu, joka on ZFS-valmis [27] .

FUSE

Google Summer of Code -aloite sponsoroi ZFS:n Linux -sovitusta käyttämällä FUSE -moduulia , joka käyttää ZFS-tiedostojärjestelmää käyttäjätilassa [28] . Uskotaan, että tämä ratkaisu on teoreettisesti täynnä suorituskyvyn menetyksiä [29] . Mutta esimerkki NTFS:n ( NTFS-3G ) toteuttamisesta FUSE:n kautta osoittaa hyvää suorituskykyä muihin järjestelmiin verrattuna [30] , mikä antaa aihetta ennustaa ZFS-FUSE:n hyväksyttävää suorituskykyä.

Vuoden 2012 lopussa ZFS-FUSE [31] esiteltiin versiona 0.7.0, joka sisälsi lähes täydellisen tuen ZFS:lle ja sen kaikille toiminnoille – tuki poolin 23. versiolle otettiin käyttöön.

FreeBSD

Pawel Jakub Dawidek on mukauttanut ZFS:n FreeBSD :lle ydinmoduuliksi. ZFS sisältyy FreeBSD 7.0:aan (julkaistu 27. helmikuuta 2008) [32] .

ZFSv28-koodi on testattu FreeBSD 9:ssä ja siirretty vakaaseen kehityshaaraan 8. FreeBSD 8.3, 8.4 ja 9.0 -julkaisut tukevat ZFS-poolin versiota 28. FreeBSD 9.2 -julkaisu ja FreeBSD:n uudemmat versiot käyttävät uusia "ominaisuuslippujen" ominaisuuksia, jotka perustuvat Poolin version 5000 toteutukseen [33] .

On huomionarvoista, että FreeBSD:ssä versiosta 8 lähtien ZFS, toisin kuin Linux, ei vaadi FUSE:n läsnäoloa, joten siihen ei liity suorituskykyongelmia. Tämän vahvistaa se tosiasia, että FreeBSD:n ZFS sisältyy ytimeen ja on järjestelmässä välittömästi läsnä, muun muassa mahdollistaen käyttöjärjestelmän käynnistämisen ZFS-taltioista. Ja FUSE-moduuli ei sisälly käyttöjärjestelmään, ja se voidaan valinnaisesti asentaa porttikokoelmasta [34] (jota tarvitaan esimerkiksi NTFS:n tukemiseen).

Mac OS X

Apple on yrittänyt siirtää ZFS:ää Mac OS X :ään, ja ZFS-postituslistoista ja alustavista leikkauksista Applen Mac OS X :n seuraavaan versioon on keskusteltu aktiivisesti [35] . Vaikka Mac OS X 10.5 (9A321) tukee ZFS:ää, se ei pysty käyttämään ZFS:ää juuriosioissa, eikä sillä ole kykyä alustaa paikallisia asemia ZFS:n alla (jälkimmäistä pidetään virheenä [36] ).

Kesäkuussa 2009 Apple hylkäsi WWDC '09 -lehdistötilaisuudessa ZFS:n esitetyssä Mac OS X 10.6 Snow Leopardin versiossa , kaikki viittaukset ZFS:ään poistettiin dokumentaatiosta ja sivuston materiaaleista. Yritys ei paljasta syitä olla käyttämättä ZFS:ää [37] .

Vaikka ZFS:n tuki palautettiin Mac OS X 10.6 Snow Leopard build 10A432:ssa, joka on merkitty Golden Masteriksi, ZFS-tuki poistettiin jälleen Mac OS X 10.6:n lopullisessa julkaisussa [38] .

Vastauksena ZFS:n virallisen tuen sulkemiseen ilmestyi ilmainen projekti, joka perustuu Applen aiemmin luomaan koodipohjaan, mutta eroaa järjestelmään integrointimenetelmästä. MacZFS:ää ei suoriteta ydintasolla, vaan käyttäjätasolla, MacFUSE:lla työskennellen, on valmisteltu binääripaketti, joka on koottu Git -varastossa julkaistujen lähdetekstien sekä asetusohjeiden perusteella.

redox

Redox - käyttöjärjestelmä suunnitteli käyttävänsä ZFS:ää oletustiedostojärjestelmänä, mutta siirtyi myöhemmin omaan samanlaisten periaatteiden toteutukseen - TFS [39] [40] , joka on kirjoitettu Redox-pääkielellä - Rust .

Muistiinpanot

  1. zfs/zfs_vnops.c at 12fa7f3436fbd89f4d6b00c2c076405e7a21d62f · zfsonlinux/zfs · GitHub + zfs/zfs_znode.h at 25458cbef9e59ef9ee6a7e729ab2522ed308f88f · zfsonlinux/zfs · GitHub + zfs/zfs_vfsops.c at 25458cbef9e59ef9ee6a7e729ab2522ed308f88f · zfsonlinux/zfs · GitHub
  2. ZFS: viimeinen sana tiedostojärjestelmissä (ZFS: viimeinen sana tiedostojärjestelmissä) . Sun Microsystems (14. syyskuuta 2004). Haettu 30. huhtikuuta 2006. Arkistoitu alkuperäisestä 4. kesäkuuta 2012.
  3. Jeff Bonwick. ZFS: Tiedostojärjestelmien viimeinen sana . Jeff Bonwickin blogi (31. lokakuuta 2005). Haettu 30. huhtikuuta 2006. Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  4. Sun juhlii OpenSolarisin onnistunutta yksivuotisjuhlaa . Sun Microsystems (20. kesäkuuta 2006). Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  5. Jeff Bonwick. Sanot zeta, minä sanon zetta (Sinä sanot zeta, minä sanon zetta) . Jeff Bonwickin blogi (4. toukokuuta 2006). Haettu 8. syyskuuta 2006. Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  6. 1 2 3 4 5 Melnikov, 2020 .
  7. OpenZFS-projekti käynnistyy . LWN.net ( 2013-09-17.mdy . 2022 ). Haettu : 2013-10-01.mdy . 2022 . Arkistoitu alkuperäisestä 11. lokakuuta 2016.
  8. OpenZFS-ilmoitus . OpenZFS ( 2013-09-17.mdy . 2022 ). Haettu : 2013-09-19.mdy . 2022 . Arkistoitu alkuperäisestä 2. huhtikuuta 2018.
  9. OpenZFS-historia . openzfs. Haettu : 2013-09-24.mdy . 2022 . Arkistoitu alkuperäisestä 24. joulukuuta 2013.
  10. Yksinkertaisin tarkistus osoittaa, että nykyisessä toteutuksessa yli 16 EIP:tä ei pooli voi käyttää. Tämä tarkistus on helppo tehdä itse, koska ZFS itse toimittaa 8 EIB-laitetta, vähintään satoja todellista gigatavua kohden pakkausta käytettäessä.
  11. Projektin johtajan Bonwickin mukaan "128-bittisten tiedostojärjestelmien täyttäminen ylittää maapallon datan tallennuskapasiteetin. Et voi täyttää ja tallentaa 128-bittistä tilavuutta ilman valtameren keittämistä." Esimerkki siitä, kuinka suuria nämä luvut ovat: jos luot 1000 tiedostoa sekunnissa, kestää noin 9000 vuotta ennen kuin ZFS saavuttaa tiedostorajan. Laskelma osoittaa, että vaadittu aika on 8925,5129601298833079654997463217 vuotta ottamatta huomioon levylle kirjoittamisen kulmanopeuden muutosta ja muita kuluja. Vastauksena kysymykseen ZFS:n täyttämisestä ilman valtamerten keittämistä, Bonwick kirjoittaa: ”Vaikka me kaikki haluaisimme Mooren lain pysyvän voimassa loputtomiin, kvanttimekaniikka asettaa joitakin perustavanlaatuisia rajoituksia minkä tahansa fyysisen laitteen laskentanopeuteen ja tietokapasiteettiin. Erityisesti osoitettiin, että 1 kilogramma ainetta, jota rajoittaa 1 litra tilaa, voi suorittaa enintään 10 51 toimintoa sekunnissa enintään 10 31 bitin informaatiolla [katso kuva. Seth Lloyd, " Laskennan äärimmäiset fyysiset rajat Arkistoitu alkuperäisestä 7. elokuuta 2008. .“ Nature 406, 1047-1054 (2000)]. Täysin täytetty 128-bittinen taltio sisältää 2128 lohkoa = 2137 tavua = 2140 bittiä; joten tämän bittimäärän tallentamiseen vaadittava vähimmäismassa olisi ( 2140 bittiä) / ( 1031 bittiä/kg) = 136 miljardia kg."
  12. Käyttöjärjestelmän käyttämille attribuuteille on lisärajoituksia, esimerkiksi Solaris NFS -käyttöluettelon FS-attribuutin koko on rajoitettu noin 10⁴ tavuun, mikä vastaa 2000-20 käyttäjää, riippuen sisäänkirjautumisten pituudesta ja isännät.
  13. ZFS On-Disk Specification (downlink) . Arkistoitu alkuperäisestä 28. lokakuuta 2015, Sun Microsystems, Inc.  Katso luku 2.4.
  14. Tietojen eheys . CERNin raportti (8. huhtikuuta 2007). Käyttöpäivä: 28. tammikuuta 2008. Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  15. Smokin' Mirrors . Blogin kirjoittanut Jeff Bonwick (2. toukokuuta 2006). Haettu 23. helmikuuta 2007. Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  16. ZFS Block Allokation . Jeff Bonwickin blogi (4. marraskuuta 2006). Haettu 23. helmikuuta 2007. Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  17. Samat lohkot - Upea hylkivä teippi . Flippin' off bits Weblog (12. toukokuuta 2006). Haettu 1. maaliskuuta 2007. Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  18. Tiivistelmä - Man-sivut osio 1: Käyttäjäkomennot . Käyttöpäivä: 13. tammikuuta 2016. Arkistoitu alkuperäisestä 24. lokakuuta 2016.
  19. Tiivistelmä - Man-sivut osio 3: Peruskirjaston toiminnot: fgetattr, fsetattr, getattrat, setattrat - hanki ja aseta järjestelmäattribuutit . Haettu 13. maaliskuuta 2016. Arkistoitu alkuperäisestä 11. lokakuuta 2016.
  20. Tiivistelmä - man-sivut osio 1: Käyttäjäkomennot: chmod - muuta tiedoston käyttöoikeustilaa . Haettu 13. maaliskuuta 2016. Arkistoitu alkuperäisestä 25. maaliskuuta 2016.
  21. Tiivistelmä - Man-sivut osio 1: Käyttäjäkomennot . Käyttöpäivä: 13. tammikuuta 2016. Arkistoitu alkuperäisestä 2. helmikuuta 2017.
  22. Ahrens, 2014 .
  23. OpenSolaris Project: Tuki levyn salaukselle ZFS:ssä. . OpenSolaris-projekti. Haettu 11. heinäkuuta 2008. Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  24. 12 Neil McAllister . Tuotantovalmis ZFS tarjoaa kosmisen mittakaavan tallennustilaa Linuxille. Äärimmäisen luotettava tiedostojärjestelmä nyt valmis laajaan käyttöön . Rekisteri (30. maaliskuuta 2013). Haettu 30. maaliskuuta 2013. Arkistoitu alkuperäisestä 4. huhtikuuta 2013.  
  25. Alkuperäinen tuki ZFS-tiedostojärjestelmälle on saatavilla Linuxille  : [ arch. 29. toukokuuta 2010 ] // OpenNET. - 2010 - 27. toukokuuta.
  26. Matt Ahrens, Brian Behlendorf. OpenZFS Linuxissa  (englanniksi)  (linkki ei saatavilla) . LinuxCon 2013 (17. syyskuuta 2013). Haettu 25. joulukuuta 2013. Arkistoitu alkuperäisestä 13. marraskuuta 2013.
  27. Ben Everard . Ubuntu 16.04 Se on palannut – ja se on loistava. Linux Voice, numero 27, kesäkuu 2016
  28. Ricardo Correia. ZFS:n julkistaminen FUSE/Linuxissa (26. toukokuuta 2006). Haettu 15. heinäkuuta 2006. Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  29. Tiedostojärjestelmän käyttöönotto käyttäjätilan tehtävätasolla voi aiheuttaa lisäkustannuksia, kuten kontekstin vaihtamisen . Mutta tällainen toteutus on koko mikroydinjärjestelmien teorian perusta ja on luotettavampi kuin toteutus ytimen sisällä.
  30. Szabolcs Szakacsits. NTFS-3G-luku-/kirjoitusohjaimen suorituskyky (linkki ei saatavilla) (28. marraskuuta 2007). Haettu 20. tammikuuta 2008. Arkistoitu alkuperäisestä 4. tammikuuta 2007. 
  31. ZFS Linux 0.7.0:lle . Haettu 7. marraskuuta 2012. Arkistoitu alkuperäisestä 20. marraskuuta 2012.
  32. Dawidek, Pawel ZFS sitoutui FreeBSD-pohjaan (6. huhtikuuta 2007). Haettu 6. huhtikuuta 2007. Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  33. FreeBSD 9.2-RELEASE Julkaisutiedot . FreeBSD. Käyttöpäivä: 30. syyskuuta 2013. Arkistoitu alkuperäisestä 3. lokakuuta 2013.
  34. FreeBSD Ports Collection . Haettu 21. huhtikuuta 2015. Arkistoitu alkuperäisestä 19. huhtikuuta 2015.
  35. ZFS:n siirtäminen OSX:ään . zfs-keskustelut (27. huhtikuuta 2006). Haettu 30. huhtikuuta 2006. Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  36. Mac OS X 10.5 9A326 kylvetty . InsanelyMac-foorumit (14. joulukuuta 2006). Haettu 14. joulukuuta 2006. Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  37. Linux.Org.Ru . InsanelyMac-foorumit (11. kesäkuuta 2009). Haettu 11. kesäkuuta 2009. Arkistoitu alkuperäisestä 13. lokakuuta 2012.
  38. Robin Harris - Apple potkaisee ZFS:ää peppuun . Haettu 2. syyskuuta 2009. Arkistoitu alkuperäisestä 2. syyskuuta 2009.
  39. https://github.com/redox-os/tfs Arkistoitu 26. lokakuuta 2018 Wayback Machinessa "TFS luotiin tarpeesta saada moderni tiedostojärjestelmä Redox OS:lle korvaamaan ZFS, joka osoittautui hidas toteuttaa monoliittisen rakenteensa vuoksi."
  40. https://www.phoronix.com/scan.php?page=news_item&px=TFS-File-System-Rust-ZFS Arkistoitu 18. lokakuuta 2018 Wayback Machinessa , https://www.phoronix.com/scan. php ?page=news_item&px=Redox-OS-2016-State Arkistoitu 18. lokakuuta 2018 Wayback Machinessa

Linkit

Portit

Arvostelut ja tiedot

  • ZFS Uncovered  (englanniksi)  - yleiskatsaus ZFS-tiedostojärjestelmään.
  • ZFS  (venäjä) Xgu.ru:ssa
  • Melnikov G. ZFS  : arkkitehtuuri, ominaisuudet ja erot muista tiedostojärjestelmistä: [ arch. 1. joulukuuta 2020 ] / Georgi Melnikov; Mail.ru Group // Habr. - 2020 - 1. joulukuuta.