[Sammelthread] ZFS Stammtisch

Da hast du sicher Recht, der ixgbe Treiber ist vermutlich auch einfach etwas besser unterstützt und gepflegt als der Emulex/Broadcom
Treiber oce/bge, wobei die die Nextreme onboard 1GBit (be) auch ohne Probleme gingen.
 
Wenn Du diese Anzeige nicht sehen willst, registriere Dich und/oder logge Dich ein.
@gea

Bin auf ein Problem beim Poolbenchmark (Menü: Pools->Benchmarks (simple file write tests) in der aktuellsten Version gestossen, sobald man einen verschlüsseltes
dataset verwenden will, scheint sich der benchmark aufzuhängen. Der perl Prozess im Hintergrund ist nach einiger Zeit aus der Prozessliste verschwunden, das
benchmark dataset bleibt stehen (_Pool_Benchmark...). und im napp-it Benchmarks Menüfenster passiert nichts mehr weiter.

Habe es jetzt in drei verschiedenen Browsern getestet (FF, Edge, Chrome), Mon und Acc auch jeweils deaktiviert. Nimmt man die die Standard Testvorgaben läuft es ohne
Probleme durch und die Ergebnisse werden nach kurzer Zeit angezeigt, wählt man stattdessen eine Variante bei "Encrypt test filesystem" aus, bleibt der Test unmotiviert "hängen".

Hast du eine Idee woran das liegen könnte, gibt es irgendwo ein logfile in das man mal reinschauen kann?
 
Wird daran liegen dass Verschlüssellung mit kleinen Datenblöcken z.B. mit sync massiv einbricht.
Der Browser der die Verbindung am längsten hält ist normalerweise Chrome aber auch da gibts irgendwann timeout der auch dafür sorgt dass der Perl cgi Prozess beendet wird.

Alternativ einen Test laufen lassen der nicht über cgi interaktiv sondern lokal im Hintergrund läuft.
 
Pool > Benchmark geht über cgi
Pool > Benchmark > bonnie läuft im Hintergrund

ansonst: lange laufende Benchmark local auf der Console starten z.B.
/var/web-gui/data/tools/filebench/filebench


Die kürzer laufenden schnelleren Benchmarks sind aber meist ausreichend aussagekräftig.
 
Ich bin auf ein merkwürdiges Phänomen gestossen, welches ich mir nicht wirklich erklären kann. Kann es eventuell ein
bug in der aktuelle 25.01a Version von napp-it sein? Die Anzeigen war nicht von Anfang an so merkwürdig, dies entstand
erst im Verlauf des Datenumzugs.


1736639519715.png



Ich habe mal grob versucht einen Teil Werte aus der Tabelle direkt abzufragen, das Ergebnis sind dann doch etwas anders aus.

Code:
root@NAS01:~# zfs list -o name,avail,used,reservation,refreservation,quota,refquota,special_small_blocks,sync,compression,dedup,encryption,readonly /storage /storage/archiv /storage/backup_appliance
NAME                      AVAIL   USED  RESERV  REFRESERV  QUOTA  REFQUOTA  SPECIAL_SMALL_BLOCKS      SYNC  COMPRESS          DEDUP   ENCRYPTION  RDONLY
storage                   11,2T  4,31T    none      1,41T   none      none                     0  standard       off            off          off     off
storage/archiv            9,79T  1,12T    none       none   none      none                     0  standard       lz4            off  aes-256-gcm     off
storage/backup_appliance  9,79T  4,60M    none       none   none      none                     0  standard       off            off          off     off


/Update - Info aus ZFS-Info
Code:
ZFSinfos hash zfs:
 all_clones         
 allfs       rpool storage storage/archiv storage/backup_appliance storage/misc storage/nfs_backup storage/scan storage/share
 allpools       rpool storage
 allvol       storage/iscsi_pbs
 datapools       storage
 properties       name type creation used avail refer ratio mounted origin quota reserv volsize volblock recsize mountpoint sharenfs checksum compress atime devices exec setuid rdonly zoned snapdir aclmode aclinherit aclimpl createtxg canmount xattr copies version utf8only normalization case vscan nbmand sharesmb refquota refreserv guid primarycache secondarycache usedsnap usedds usedchild usedrefreserv defer_destroy userrefs logbias dedup mlslabel sync dnsize refratio written clones lused lrefer fslimit sslimit fscount sscount redund_md resumetok special_small_blocks encryption keylocation keyformat pbkdf2iters encroot keystatus org.opensolaris.libbe:uuid org.opensolaris.libbe:policy enc_smbak: enc_automount: enc_smbshare: enc_split: lu:guid
 rpool/dump_avail       701G
 rpool/dump_mountpoint       -
 rpool/dump_refer       8.00G
 rpool/dump_type       volume
 rpool/dump_used       8.00G
 rpool/swap_avail       709G
 rpool/swap_mountpoint       -
 rpool/swap_refer       639M
 rpool/swap_type       volume
 rpool/swap_used       8.50G
 rpool_avail       701G
 rpool_compression       lz4
 rpool_config       ONLINE 0 0 0\n c1t58CE38EE200A3DE6d0 ONLINE 0 0 0
 rpool_dedup       off
 rpool_dv       drwxr-xr-x 3 root root 3 Dec 28 21:24 /rpool\n owner@:rwxp-DaARWcCos:-------:allow\n group@:r-x---a-R-c--s:-------:allow\n everyone@:r-x---a-R-c--s:-------:allow\n
 rpool_enc_split:       -
 rpool_encryption       off
 rpool_encryptionroot       -
 rpool_errors       No known data errors
 rpool_hasS3         
 rpool_keystatus       -
 rpool_ls       drwxr-xr-x 3 root root 3 Dec 28 21:24:58 2024 /rpool
 rpool_members       c1t58CE38EE200A3DE6d0
 rpool_mountpoint       /rpool
 rpool_nbmand       off
 rpool_origin       -
 rpool_quota       none
 rpool_readonly       off
 rpool_recsize       128K
 rpool_refquota       none
 rpool_refreservation       none
 rpool_reservation       none
 rpool_scan       scrub repaired 0B in 0 days 00:00:12 with 0 errors on Sun Jan 05 22:00:13 2025
 rpool_sharenfs       off
 rpool_sharesmb       off
 rpool_shdv         
 rpool_state       ONLINE
 rpool_sync       standard
 rpool_used       19,3G
 specialpools         
 storage/archiv_avail       7,74T
 storage/archiv_compression       lz4
 storage/archiv_dedup       off
 storage/archiv_dv       drwxrwxrwx+ 20 root root 36 Jan 11 17:21 /storage/archiv\n user:root:rwxpdDaARWcCos:fd-----:allow\n everyone@:rwxpdDaARWc--s:fd-----:allow\n
 storage/archiv_enc_split:       prompt
 storage/archiv_encryption       aes-256-gcm
 storage/archiv_encryptionroot       storage/archiv
 storage/archiv_hasS3         
 storage/archiv_keystatus       available
 storage/archiv_ls       drwxrwxrwx+ 20 root root 36 Jan 11 17:21:08 2025 /storage/archiv
 storage/archiv_mountpoint       /storage/archiv
 storage/archiv_nbmand       on
 storage/archiv_origin       -
 storage/archiv_quota       none
 storage/archiv_readonly       off
 storage/archiv_recsize       128K
 storage/archiv_refquota       none
 storage/archiv_refreservation       none
 storage/archiv_reservation       none
 storage/archiv_sharenfs       off
 storage/archiv_sharesmb       name=archiv
 storage/archiv_shdv       ----------+ 1 root root 0 Jan 11 16:10 /storage/archiv/.zfs/shares/archiv\n user:joker:rwxpdDaARWcCos:fd-----:allow\n
 storage/archiv_sync       standard
 storage/archiv_used       1,12T
 storage/backup_appliance_avail       4,60M
 storage/backup_appliance_compression       on
 storage/backup_appliance_dedup       latency
 storage/backup_appliance_dv         
 storage/backup_appliance_enc_split:       -
 storage/backup_appliance_encryption       off
 storage/backup_appliance_encryptionroot       -
 storage/backup_appliance_hasS3         
 storage/backup_appliance_keystatus       -
 storage/backup_appliance_ls       -
 storage/backup_appliance_mountpoint       128K
 storage/backup_appliance_nbmand       off
 storage/backup_appliance_origin       yes
 storage/backup_appliance_quota       -
 storage/backup_appliance_readonly       on
 storage/backup_appliance_recsize       -
 storage/backup_appliance_refquota       off
 storage/backup_appliance_refreservation       none
 storage/backup_appliance_reservation       none
 storage/backup_appliance_sharenfs       /storage/backup_appliance
 storage/backup_appliance_sharesmb       off
 storage/backup_appliance_shdv         
 storage/backup_appliance_sync       none
 storage/backup_appliance_used       4 14:10 2025
 storage/iscsi_pbs_avail       7.74T
 storage/iscsi_pbs_compression       off
 storage/iscsi_pbs_dedup       off
 storage/iscsi_pbs_dv         
 storage/iscsi_pbs_ls       -
 storage/iscsi_pbs_mountpoint       -
 storage/iscsi_pbs_nbmand       -
 storage/iscsi_pbs_origin       -
 storage/iscsi_pbs_quota       -
 storage/iscsi_pbs_readonly       off
 storage/iscsi_pbs_recsize       -
 storage/iscsi_pbs_refer       87.4G
 storage/iscsi_pbs_refquota       -
 storage/iscsi_pbs_refreservation       none
 storage/iscsi_pbs_reservation       none
 storage/iscsi_pbs_sharenfs       -
 storage/iscsi_pbs_sharesmb       -
 storage/iscsi_pbs_shdv         
 storage/iscsi_pbs_sync       standard
 storage/iscsi_pbs_type       volume
 storage/iscsi_pbs_used       87.4G
 storage/misc_avail       7,74T
 storage/misc_compression       lz4
 storage/misc_dedup       off
 storage/misc_dv       drwxrwxrwx+ 5 root root 1090 Jan 12 00:03 /storage/misc\n user:root:rwxpdDaARWcCos:fd-----:allow\n everyone@:rwxpdDaARWc--s:fd-----:allow\n
 storage/misc_enc_split:       prompt
 storage/misc_encryption       aes-256-gcm
 storage/misc_encryptionroot       storage/misc
 storage/misc_hasS3         
 storage/misc_keystatus       available
 storage/misc_ls       drwxrwxrwx+ 5 root root 1090 Jan 12 00:03:40 2025 /storage/misc
 storage/misc_mountpoint       /storage/misc
 storage/misc_nbmand       on
 storage/misc_origin       -
 storage/misc_quota       none
 storage/misc_readonly       off
 storage/misc_recsize       128K
 storage/misc_refquota       none
 storage/misc_refreservation       none
 storage/misc_reservation       none
 storage/misc_sharenfs       off
 storage/misc_sharesmb       abe=true,name=misc
 storage/misc_shdv       -rwx------+ 1 root root 0 Jan 11 21:04 /storage/misc/.zfs/shares/misc\n user:root:rwxpdDaARWcCos:-------:allow\n user:joker:rwxpdDaARWcCos:fd-----:allow\n user:magentatv:rwxpdDaARWcCos:fd-----:allow\n
 storage/misc_sync       standard
 storage/misc_used       713G
 storage/nfs_backup_avail       7,74T
 storage/nfs_backup_compression       lz4
 storage/nfs_backup_dedup       off
 storage/nfs_backup_dv       drwxrwxrwx+ 9 root root 9 Jan 11 16:12 /storage/nfs_backup\n groupsid:Local System@:rwxp--aARWc--s:fd-----:allow\n user:root:rwxpdDaARWcCos:fd-----:allow\n user:joker:rwxpdDaARWcCos:fd-----:allow\n everyone@:rwxpdDaARWcCos:fd-----:allow\n
 storage/nfs_backup_enc_split:       -
 storage/nfs_backup_encryption       off
 storage/nfs_backup_encryptionroot       -
 storage/nfs_backup_hasS3         
 storage/nfs_backup_keystatus       -
 storage/nfs_backup_ls       drwxrwxrwx+ 9 root root 9 Jan 11 16:12:30 2025 /storage/nfs_backup
 storage/nfs_backup_mountpoint       /storage/nfs_backup
 storage/nfs_backup_nbmand       on
 storage/nfs_backup_origin       -
 storage/nfs_backup_quota       none
 storage/nfs_backup_readonly       off
 storage/nfs_backup_recsize       128K
 storage/nfs_backup_refquota       none
 storage/nfs_backup_refreservation       none
 storage/nfs_backup_reservation       none
 storage/nfs_backup_sharenfs       root=@192.168.1.40:@192.168.1.41,rw=@192.168.1.40:@192.168.1.41
 storage/nfs_backup_sharesmb       name=nfs_backup
 storage/nfs_backup_shdv       -rwx------+ 1 root root 0 Jan 11 12:37 /storage/nfs_backup/.zfs/shares/nfs_backup\n user:root:rwxpdDaARWcCos:-------:allow\n user:joker:rwxpdDaARWcCos:fd-----:allow\n user:wdtv:rwxpdDaARWcCos:fd-----:allow\n
 storage/nfs_backup_sync       standard
 storage/nfs_backup_used       1014G
 storage/scan_avail       7,74T
 storage/scan_compression       lz4
 storage/scan_dedup       off
 storage/scan_dv       drwxrwxrwx+ 3 root root 7 Jan 10 12:50 /storage/scan\n user:root:rwxpdDaARWcCos:fd-----:allow\n everyone@:rwxpdDaARWc--s:fd-----:allow\n
 storage/scan_enc_split:       -
 storage/scan_encryption       off
 storage/scan_encryptionroot       -
 storage/scan_hasS3         
 storage/scan_keystatus       -
 storage/scan_ls       drwxrwxrwx+ 3 root root 7 Jan 10 12:50:35 2025 /storage/scan
 storage/scan_mountpoint       /storage/scan
 storage/scan_nbmand       on
 storage/scan_origin       -
 storage/scan_quota       none
 storage/scan_readonly       off
 storage/scan_recsize       128K
 storage/scan_refquota       none
 storage/scan_refreservation       none
 storage/scan_reservation       none
 storage/scan_sharenfs       off
 storage/scan_sharesmb       name=scan,guestok=true
 storage/scan_shdv       ----------+ 1 root root 0 Jan 10 11:18 /storage/scan/.zfs/shares/scan\n user:joker:rwxpdDaARWcCos:fd-----:allow\n user:hp:rwxpdDaARWcCos:fd-----:allow
 storage/scan_sync       standard
 storage/scan_used       1,66M
 storage/share_avail       7,74T
 storage/share_compression       lz4
 storage/share_dedup       off
 storage/share_dv       drwxrwxrwx+ 8 root root 12 Dec 28 11:39 /storage/share\n user:root:rwxpdDaARWcCos:fd-----:allow\n everyone@:rwxpdDaARWc--s:fd-----:allow
 storage/share_enc_split:       prompt
 storage/share_encryption       aes-256-gcm
 storage/share_encryptionroot       storage/share
 storage/share_hasS3         
 storage/share_keystatus       available
 storage/share_ls       drwxrwxrwx+ 8 root root 12 Dec 28 11:39:03 2024 /storage/share
 storage/share_mountpoint       /storage/share
 storage/share_nbmand       on
 storage/share_origin       -
 storage/share_quota       none
 storage/share_readonly       off
 storage/share_recsize       128K
 storage/share_refquota       none
 storage/share_refreservation       none
 storage/share_reservation       none
 storage/share_sharenfs       off
 storage/share_sharesmb       name=share
 storage/share_shdv         
 storage/share_sync       standard
 storage/share_used       2,04T
 storage_avail       6,35T
 storage_compression       on
 storage_config       ONLINE 0 0 0\n mirror-0 ONLINE 0 0 0\n c7t5000039D7838BF3Ad0 ONLINE 0 0 0\n c8t5000039D7838B4D2d0 ONLINE 0 0 0\n logs \n c2t5000CCA013276D9Dd0 ONLINE 0 0 0
 storage_dedup       latency
 storage_dv         
 storage_enc_split:       -
 storage_encryption       off
 storage_encryptionroot       -
 storage_errors       No known data errors
 storage_hasS3         
 storage_iscsi_LU       600144F00006116B0000678269C90001
 storage_iscsi_LU_view       View Entry: 0\n Host group : All\n Target group : All\n LUN : 0
 storage_iscsi_vol       pbs
 storage_iscsi_vol_size       7827400000
 storage_iscsi_vol_size2       7.8T
 storage_keystatus       -
 storage_ls       -
 storage_members       c7t5000039D7838BF3Ad0 c8t5000039D7838B4D2d0 c2t5000CCA013276D9Dd0
 storage_mountpoint       128K
 storage_nbmand       off
 storage_origin       yes
 storage_quota       -
 storage_readonly       on
 storage_recsize       -
 storage_refquota       off
 storage_refreservation       none
 storage_reservation       none
 storage_scan       scrub repaired 0B in 0 days 00:00:01 with 0 errors on Sat Jan 04 14:17:03 2025
 storage_sharenfs       /storage
 storage_sharesmb       off
 storage_shdv         
 storage_state       ONLINE
 storage_sync       none
 storage_used       4 14:05 2025
 syspool       rpool
 volumes       rpool/dump rpool/swap storage/iscsi_pbs
 
Zuletzt bearbeitet:
Used, refres und dedup (logbias) sind fehlerhaft
Da ich das Problem bei mir nicht sehe, welche Ausgabe hat Menü ZFS Filesystems > ZFS info ?
Das zeigt die Werte die napp-it bei Aufruf des Menüs ermittelt hat (als code einfügen)
 
Habs mal im vorangegangen Eintrag ergänzt, auch dort sehen die Werte teils merkwürdig aus, auch im Hinblick auf z.B. readonly.
 
Datenumzug war Solaris -> OmniOS?
mit umkopieren via robocopy?

Sonst was besonderes beim Umzug?

Napp-it ermittelt Werte via 'zfs list -o all' und macht dann noch eine Bearbeitung der Datumsangaben
Da könnte es eventuell ein Problem geben

Bitte folgende Befehle ausführen
zfs list -o all | grep TYPE > /tmp/zfs.log
zfs list -o all | grep backup_appliance >> /tmp/zfs.log

In /tmp/zfs.log stehen jetzt die Headers und Werte für das Dateisystem. (Lesen mit WinSCP oder type auf console)
Das könnte helfen das Problem zu erkennen
 
Hi gea,

ja, Umzug war von Solaris -> OmniOS, Größtenteils umkopieren via robocopy, ein Teil via rsync wegen Problemen mit Umlauten.
Es gab erst noch Probleme beim putty Terminal, mit der Eingabe und Anzeige von Umlauten und Co. in der Console Hierzu musste
die Localisation dann auf OOCE noch umgestellt werden (aktuell de_DE.UTF-8 / charmap German) - Altsystem Solaris (en_US.UTF-8 /
charmap US-English)

OmnisOS:
Code:
NAME                                       TYPE        CREATION                 USED  AVAIL     REFER  RATIO  MOUNTED  ORIGIN                                          QUOTA  RESERV  VOLSIZE  VOLBLOCK  RECSIZE  MOUNTPOINT                 SHARENFS                                                          CHECKSUM  COMPRESS  ATIME  DEVICES  EXEC  SETUID  RDONLY  ZONED  SNAPDIR      ACLMODE     ACLINHERIT  ACLIMPL  CREATETXG  CANMOUNT  XATTR  COPIES  VERSION  UTF8ONLY  NORMALIZATION         CASE  VSCAN  NBMAND  SHARESMB                REFQUOTA  REFRESERV   GUID  PRIMARYCACHE  SECONDARYCACHE  USEDSNAP  USEDDS  USEDCHILD  USEDREFRESERV  DEFER_DESTROY  USERREFS     LOGBIAS          DEDUP  MLSLABEL      SYNC  DNSIZE  REFRATIO  WRITTEN  CLONES  LUSED  LREFER  FSLIMIT  SSLIMIT  FSCOUNT  SSCOUNT  REDUND_MD  RESUMETOK  SPECIAL_SMALL_BLOCKS   ENCRYPTION  KEYLOCATION   KEYFORMAT  PBKDF2ITERS  ENCROOT           KEYSTATUS  ORG.OPENSOLARIS.LIBBE:UUID            ORG.OPENSOLARIS.LIBBE:POLICY  ENC_SMBAK:     ENC_AUTOMOUNT:  ENC_SMBSHARE:         ENC_SPLIT:  LU:GUID
storage/backup_appliance                   filesystem  Sa. Jan.  4 14:10 2025  4,60M  7,74T     4,60M  1.00x      yes  -                                                none    none        -         -     128K  /storage/backup_appliance  off                                                                     on       off     on       on    on      on     off    off   hidden  passthrough    passthrough       on         97        on     on       1        5       off           none    sensitive    off     off  off                         none       none  10996410470758899489           all             all        0B   4,60M         0B             0B              -         -     latency            off  none      standard  legacy     1.00x        0  -       4,22M   4,22M     none     none     none     none        all  -                             0          off  none               none            0  -                         -  -                                     -                             -              -               -                     -           -


Zum Vergleich Altsystem:
Code:
NAME                                                         ACLINHERIT      ACLMODE  ATIME  AVAIL  CANMOUNT         CASE    CHECKSUM  COMPRESS  RATIO  COPIES  CREATION                       DEDUP  DEFAULTGROUPQUOTA  DEFAULTREADLIMIT  DEFAULTUSERQUOTA  DEFAULTWRITELIMIT  DEFER_DESTROY  DEVICES  EFFECTIVEREADLIMIT  EFFECTIVEWRITELIMIT        CRYPT  EXEC  KEYCHANGEDATE  KEYSOURCE            KEYSTATUS     LOGBIAS  MLSLABEL  MOUNTED  MOUNTPOINT                   MLDS  NBMAND  NORMALIZATION  ORIGIN                                            PRIMARYCACHE  QUOTA  READLIMIT  RDONLY  RECSIZE  REFER  REFQUOTA  REFRESERV  REKEYDATE  RESERV  RSTCHOWN  SECONDARYCACHE  SETUID  SHADOW    SHARENFS  SHARESMB  SNAPDIR      SYNC  TYPE         USED  USEDCHILD  USEDDS  USEDREFRESERV  USEDSNAP  USERREFS  UTF8ONLY  VERSION  VOLBLOCK  VOLSIZE  VSCAN  WRITELIMIT  XATTR  ZONED  COM.ORACLE.LIBBE:BE-POLICY  COM.ORACLE.LIBBE:POOL_VERSION  ORG.OPENSOLARIS.LIBBE:UUID            ORG.OPENSOLARIS.LIBBE:POLICY  COM.ORACLE.LIBBE:LAST-BOOT-TIME  ENC_SMBSHARE:                 ENC_AUTOMOUNT:  ENC_SPLIT:
storage/backup_appliance                                    passthrough  passthrough     on   4.5T        on        mixed          on       off  1.00x       1  Thu Aug 30 17:34 2018            off               none              none              none               none              -       on                none                 none          off    on  -              none                      none     latency  none          yes  /storage/backup_appliance     off     off           none  -                                                          all   none    default     off     128K  2.05M      none       none  -            none        on             all      on  none      -         -          hidden  standard  filesystem   110M          0   2.05M              0      108M         -       off        6         -        -    off     default     on    off  -                           -                              -                                     -                             -                                -                             -               -
 
Ich vermute in der Tat das Problem liegt an localisation und Datum, eventuell Umlauten.
Um das einzugrenzen brauche ich die "Rohdaten" in zfs.log

zfs list -o all | grep TYPE > /tmp/zfs.log
zfs list -o all | grep backup_appliance >> /tmp/zfs.log
 
Das ergibt aber offenbar den gleichen output, oder sollte es ein anderer Befehl werden?

/Edit
Deine These ist richtig, mit dem Zeichensatz en_US.UTF-8 ist die Anzeige wieder in Ordnung. Dass passt auch zeitlich
Einigermaßen in den zeitlichen Gesamtablauf mit der Anpassung von C auf UTF-8 und der festgestellten Abweichung
in der GUI.
 
Zuletzt bearbeitet:
Das ergibt aber offenbar den gleichen output, oder sollte es ein anderer Befehl werden?
zfs list -o all | grep TYPE
Das listed die Namen der Properties (Headers). Eine der Headers ist TYPE

zfs list -o all | grep backup_appliance
Das listet die Properties dieses Dateisystems backup_appliance
 
Siehe aber auch #13.661

Code:
NAME                                       TYPE        CREATION                 USED  AVAIL     REFER  RATIO  MOUNTED  ORIGIN                                          QUOTA  RESERV  VOLSIZE  VOLBLOCK  RECSIZE  MOUNTPOINT                 SHARENFS                                                          CHECKSUM  COMPRESS  ATIME  DEVICES  EXEC  SETUID  RDONLY  ZONED  SNAPDIR      ACLMODE     ACLINHERIT  ACLIMPL  CREATETXG  CANMOUNT  XATTR  COPIES  VERSION  UTF8ONLY  NORMALIZATION         CASE  VSCAN  NBMAND  SHARESMB                REFQUOTA  REFRESERV   GUID  PRIMARYCACHE  SECONDARYCACHE  USEDSNAP  USEDDS  USEDCHILD  USEDREFRESERV  DEFER_DESTROY  USERREFS     LOGBIAS          DEDUP  MLSLABEL      SYNC  DNSIZE  REFRATIO  WRITTEN  CLONES  LUSED  LREFER  FSLIMIT  SSLIMIT  FSCOUNT  SSCOUNT  REDUND_MD  RESUMETOK  SPECIAL_SMALL_BLOCKS   ENCRYPTION  KEYLOCATION   KEYFORMAT  PBKDF2ITERS  ENCROOT           KEYSTATUS  ORG.OPENSOLARIS.LIBBE:UUID            ORG.OPENSOLARIS.LIBBE:POLICY  ENC_SMBAK:     ENC_AUTOMOUNT:  ENC_SMBSHARE:         ENC_SPLIT:  LU:GUID
storage/backup_appliance                   filesystem  Sa. Jan.  4 14:10 2025  4,65M  7,74T     4,60M  1.00x      yes  -                                                none    none        -         -     128K  /storage/backup_appliance  off                                                                     on       off     on       on    on      on     off    off   hidden  passthrough    passthrough       on         97        on     on       1        5       off           none    sensitive    off     off  off                         none       none  10996410470758899489           all             all       56K   4,60M         0B             0B              -         -     latency            off  none      standard  legacy     1.00x        0  -       4,25M   4,22M     none     none     none     none        all  -                             0          off  none               none            0  -                         -  -                                     -                             -              -               -                     -           -
 
Die Datumslocalisation mit dem Punkt in "Jan. 4" statt "Jan 4" scheint das Problem zu verursachen.
Das habe ich in 25.dev geändert. Da sollte das Problem behoben sein.

In OpenZFS 2.3 wird es eine Json Ausgabeoption geben. Damit wird es einfacher Properties zu trennen. Aktuell hat man das Problem dass Werte durch ein Leerzeichen getrennt werden. Jan 4 hat aber zwei Leerzeichen....
 
Man soll ja auch eigentlich keine Server und Co. mit deutscher Sprache betreiben 😉 - birgt immer das Potential für unerwartete Probleme.

Schaut in der 25.dev aber nun wieder in Ordnung aus (y)

1736715254466.png
 
OpenZFS 2.3 release

wichtigste Neuerungen
- Raid-Z expansion
- Fast Dedup
- Direct IO
 
no risk, no fun
man kann aber auch ein paar Monate mit den neuen Features warten.
 
Zuletzt bearbeitet:
Mal ne Frage: Ich sichere mein ZFS Homelab über ein Shell-Script, dass mir den ZFS Datenstream vom Hauptsystem (`rpool`, 2TB NVMe) auf eine externe USB-Platte (`rpoolbak`, Festplatte 8TB) schiebt (mit `--raw` weil native encryption):

Bash:
# Das erste mal mit
zfs send --raw -R "rpool@backup-2025-01-16" | pv | zfs recv -Fdu "rpoolbak"

# Danach inkrementell mit
zfs send --raw -RI "rpool@backup-2025-01-16" "rpool@backup-2025-01-17" | pv | zfs recv -Fdu "rpoolbak"

Das funktioniert erstmal gut soweit. Jetzt ist die Sicherung aber natürlich jetzt mal so gestaltet, dass die keine alten Snapshots wegwirft (wie `zfs-auto-snapshot` das nach ner Zeit automatisch tut) und ich komme langsam an den Punkt, wo meine externe Platte so viele Snapshots hat, dass ich die beim Wiederherstellen nicht einfach zurückspielen kann, weil die Datenmenge größer ist, als das was auf die 2TB Platte passt.

Möchte ich das ganze also wiederherstellen, etwa so:

Bash:
# rpool/ROOT + rpool/ROOT/pve-1
zfs send --raw -R rpoolbak/ROOT@backup-2025-01-17 | pv | zfs recv -u rpool/ROOT
# rpool/data
zfs send --raw -R rpoolbak/data@backup-2025-01-17 | pv | zfs recv -u rpool/data
# rpool/var-lib-vz
zfs send --raw -R rpoolbak/var-lib-vz@backup-2025-01-17 | pv | zfs recv -u rpool/var-lib-vz

klappt das nicht, weil ich keinen Weg gefunden habe, die nur die Daten des letzten Snapshots (kumuliert) zu senden oder zumindest nur einen Bereich (z.B. die letzten 30 Tage). Zur Info:


Bash:
zfs send --raw -RI "rpool/ROOT@backup-2025-01-16" "rpool/ROOT@backup-2025-01-17" | pv | zfs recv -u "rpoolbak/ROOT"
zfs send --raw -RI "rpool/data@backup-2025-01-16" "rpool/data@backup-2025-01-17" | pv | zfs recv -u "rpoolbak/data"
zfs send --raw -RI "rpool/var-lib-vz@backup-2025-01-16" "rpool/var-lib-vz@backup-2025-01-17" | pv | zfs recv -u "rpoolbak/var-lib-vz"

um nur die Daten zwischen dem 16.01.-17.01 zu senden, hat bei ersten Tests nicht funktioniert (Fehlermeldung habe ich nicht mehr... ich erkläre mir das so, dass die ganze Kette vorhanden sein muss, damit das funktioniert).

Kann ich kumulierte Snapshots senden oder muss ich auf dem rpoolbak die alten Snapshots wegwerfen (das würde ich nur ungern machen, solange noch Platz ist)? Oder müsste das sogar wie oben beschrieben funktionieren und ich hab nur irgendwo einen Fehler gemacht?

@gea Kannst du da vielleicht weiterhelfen?
 
Zuletzt bearbeitet:
Ich verwende die AIO-Lösung (inkl. napp-it von gea) nun schon seit Ewigkeiten (ich müsste nachsehen, aber vermutlich 10+ Jahre) im Homelab unter ESXi.
Zwischenzeitlich bin ich mal auf Proxmox umgestiegen, bin da aber aus verschiedenen Gründen wieder zurück zu ESXi. Aufgrund der Lizenzthematik möchte ich nun aber den Schritt von ESXi nach Proxmox noch einmal wagen.

Proxmox liefert ZFS im Basissystem mit. Was ist allerdings "best practice" für den Betrieb?
Den Filer direkt auf Proxmox betreiben oder den Filer in eine VM sperren?

In meiner Zeit bei Proxmox habe die ZFS-Filesysteme direkt unter Proxmox zur Verfügung gestellt. So richtig glücklich war ich damit jedoch nicht. Performance war nicht auf dem Niveau des CIFS-Servers unter Solaris/Omnios, Handling von ACLs unter Solaris war deutlich einfacher und besonders schwerwiegend: "Vorgängerversionen" (für den direkten Zugriff auf Snaps unter Windows) habe ich massiv vermisst.
Seinerzeit habe ich es aber auch nicht hinbekommen, eine Omnios-VM (mit napp-it) performant in einer VM zum Laufen zu bringen.
Best case für mich wäre, wenn ich meine bestehende Omnios-VM vom ESXi auf den Proxmox-Server schieben und diese dort 1:1 weiterverwenden könnte. Gibt es dazu Erfahrungen?

Wie und in welcher Form betreibt ihr hier in der Community eure ZFS-Filer unter Proxmox?

Vielen Dank vorab!
 
Wie und in welcher Form betreibt ihr hier in der Community eure ZFS-Filer unter Proxmox?
ICH (so macht es sonst keiner) betreibe einen Docker-LXC, für den ich den storage durchreiche (das geht nur bei LXCs, nicht bei VMs)

Code:
mp0: /rpool/data/docker,mp=/var/lib/docker
mp1: /rpool/data/shared,mp=/mnt/

Anschließend nehme ich dann einen Docker Samba (sowas hier: https://github.com/crazy-max/docker-samba) um die Freigaben zu konfigurieren.


Du scheinst aber eher auf sowas hier abzuzielen:

Das ist ein LXC mit ZFS, Samba-Versionierung und allem sonst. Video dazu:

Die bieten auch Schulungen an, die sollen hervorragend sein, habe ich mir sagen lassen (https://aow.de/books/sysopstv-kurse/page/schulungsangebote-aus-der-betriebspraxis)
 
Die LXC Variante wird hier auch empfohlen:

cu
Beitrag automatisch zusammengeführt:

Mal ne Frage: Ich sichere mein ZFS Homelab über ein Shell-Script, dass mir den ZFS Datenstream vom Hauptsystem (`rpool`, 2TB NVMe) auf eine externe USB-Platte (`rpoolbak`, Festplatte 8TB) schiebt (mit `--raw` weil native encryption):

Bash:
# Das erste mal mit
zfs send --raw -R "rpool@backup-2025-01-16" | pv | zfs recv -Fdu "rpoolbak"

# Danach inkrementell mit
zfs send --raw -RI "rpool@backup-2025-01-16" "rpool@backup-2025-01-17" | pv | zfs recv -Fdu "rpoolbak"

Das funktioniert erstmal gut soweit. Jetzt ist die Sicherung aber natürlich jetzt mal so gestaltet, dass die keine alten Snapshots wegwirft (wie `zfs-auto-snapshot` das nach ner Zeit automatisch tut) und ich komme langsam an den Punkt, wo meine externe Platte so viele Snapshots hat, dass ich die beim Wiederherstellen nicht einfach zurückspielen kann, weil die Datenmenge größer ist, als das was auf die 2TB Platte passt.

Möchte ich das ganze also wiederherstellen, etwa so:

Bash:
# rpool/ROOT + rpool/ROOT/pve-1
zfs send --raw -R rpoolbak/ROOT@backup-2025-01-17 | pv | zfs recv -u rpool/ROOT
# rpool/data
zfs send --raw -R rpoolbak/data@backup-2025-01-17 | pv | zfs recv -u rpool/data
# rpool/var-lib-vz
zfs send --raw -R rpoolbak/var-lib-vz@backup-2025-01-17 | pv | zfs recv -u rpool/var-lib-vz

klappt das nicht, weil ich keinen Weg gefunden habe, die nur die Daten des letzten Snapshots (kumuliert) zu senden oder zumindest nur einen Bereich (z.B. die letzten 30 Tage). Zur Info:


Bash:
zfs send --raw -RI "rpool/ROOT@backup-2025-01-16" "rpool/ROOT@backup-2025-01-17" | pv | zfs recv -u "rpoolbak/ROOT"
zfs send --raw -RI "rpool/data@backup-2025-01-16" "rpool/data@backup-2025-01-17" | pv | zfs recv -u "rpoolbak/data"
zfs send --raw -RI "rpool/var-lib-vz@backup-2025-01-16" "rpool/var-lib-vz@backup-2025-01-17" | pv | zfs recv -u "rpoolbak/var-lib-vz"

um nur die Daten zwischen dem 16.01.-17.01 zu senden, hat bei ersten Tests nicht funktioniert (Fehlermeldung habe ich nicht mehr... ich erkläre mir das so, dass die ganze Kette vorhanden sein muss, damit das funktioniert).

Kann ich kumulierte Snapshots senden oder muss ich auf dem rpoolbak die alten Snapshots wegwerfen (das würde ich nur ungern machen, solange noch Platz ist)? Oder müsste das sogar wie oben beschrieben funktionieren und ich hab nur irgendwo einen Fehler gemacht?

@gea Kannst du da vielleicht weiterhelfen?
Mir scheint, dir fehlt grundlegendes Verständnis, was ein Snapshot eigentlich ist?

Du kannst jederzeit problemlos Snapshots löschen, ohne Daten zu verlieren.
Du kannst alle alten Snapshots löschen, wenn du die Historie nicht mehr brauchst.
Du könntest sogar alle neuen Snapshots löschen und hättest auf dem Backup noch den Stand der aktuellsten Übertragung. Allerdings hast du dann nichts mehr, um ein weiteres inkrementelles Backup anzuhängen.
Die erste Übertragung muss immer in full send sein, dann kannst du inkrementell weitermachen.
 
Zuletzt bearbeitet:
Mir scheint, dir fehlt grundlegendes Verständnis, was ein Snapshot eigentlich ist?
Das (hoffe ich) nicht.
Du kannst jederzeit problemlos Snapshots löschen, ohne Daten zu verlieren.
Du kannst alle alten Snapshots löschen, wenn du die Historie nicht mehr brauchst.
Du könntest sogar alle neuen Snapshots löschen und hättest auf dem Backup noch den Stand der aktuellsten Übertragung.
Nun, ich kann snapshots löschen, ohne ALTE Daten zu verlieren, bzw. besser formuliert den Datenänderungsverlauf.
Problem 1: Den möchte ich aber wenns geht behalten und klonen bzw. unter `.zfs` mounten können... Es geht um die Details, nicht um die generelle Funktionsweise. Das Löschen (`zfs destroy`) und Rollback (`zfs rollback`) zwei unterschiedliche Operationen sind, ist mir klar. Die Fragen, die ich inzwischen beantworten kann sind diese:
  • Was passiert wenn ich alle Snapshots lösche - bin ich dann immernoch ohne Datenverlust?
  • Was passiert wenn ich nur den ältesten Snapshot lösche, sind dann die danach alle noch intakt oder werden die auch gelöscht, weil es ein "Baum" ist? Und so weiter...
Allerdings hast du dann nichts mehr, um ein weiteres inkrementelles Backup anzuhängen.
Und hier ist das 2. Problem. Ich möchte weiterhin gerne inkrementelle Backups machen.

Die erste Übertragung muss immer in full send sein, dann kannst du inkrementell weitermachen.
Auch das ist mir bekannt, habe ich ja oben bereits geschrieben. Ich fasse noch mal zusammen:

Ich möchte gerne meine alten Snapshots behalten,
  1. solange Platz ist (einfach weils geht - nicht weil ich es brauche)
  2. um weiterhin inkrementelle Backups zu machen (weil es schneller geht, als ein full send)
Meine Fragen (mehr Details mit Befehlen in diesem Beitrag):
  1. Entfernt ein inkrementelles Backup auf dem Ziel-Backup-Volume die Snapshots automatisch, die nicht mehr auf meinem Quell-Volume vorhanden sind und bleibt somit IMMER UNTER 2TB groß (womit ich mir eine Festplatte > 2TB schenken könnte)?
  2. Falls nicht, wächst das Backup ja irgendwan > 2TB. Wie kriege ich ein mit MEHR als 2TB inkrementellen Snapshots gefülltes Backup-Volume auf ein 2TB Volume zurück gespielt, ohne dass es überläuft und abbricht (ich kann soweit ich weiß keine Snapshots beim ersten `zfs send | zfs recv` auslassen)?
 
1, Ein zfs send/receive entfernt keine snapshots, es sei denn, du machst einen recv -f, dann könnte es passieren, das ein rollback auf dem backup passiert bevor die neuen Daten geschrieben werden.
2. indem du nur den letzten (oder einen der letzten) Stand ohne Histore zurückspielst beispielweise. Wen natürlich der full send auch schon über 2TB hat, klappt auch das nicht.
Also genau damit: zfs send --raw -R rpoolbak/ROOT@backup-2025-01-17 | pv | zfs recv -u rpool/ROOT
 
Grundlegendes
Jeder ZFS Snapshot ist eine komplette Ansicht des gesamten datasets (Zvol oder Dateisystem) zum Zeitpunkt der Erstellung,
Vorgängersnaps brauchts dazu nicht.

Eine incrementelle Replikation erstellt auf dem Quellsystem einen neuen Snap z.B. Snap 101 und überträgt geänderte Datenblöcke zum vorherigen Snap 100.

Auf dem Zielsystem wird dieser Stand Snap 100 benötigt (z.B. für ein Rollback) damit die Übertragung auch hier den Stand von 101 ergibt (Snap 101 wird bei Erfolg angelegt)
Beitrag automatisch zusammengeführt:

Proxmox liefert ZFS im Basissystem mit. Was ist allerdings "best practice" für den Betrieb?
Den Filer direkt auf Proxmox betreiben oder den Filer in eine VM sperren?

Wenn man ein besonders schnelles NAS mit Proxmox möchte, dann SAMBA oder ksmbd auf Proxmox installieren.
Als Web-GUI kann man napp-it cs unter Windows nehmen, das managt Proxmox ZFS remote

Eine Storage VM braucht halt viel RAM und Resourcen.
Rein als NAS hat eine Linux Storage VM keine Vorteile, bringt aber Komfort.

Eine OmniOS Storage VM ist etwas genügsamer, bietet viel bessere ntfs ACL Unterstützung und Snaps als vorherige Version ohne dass man etwas beachten oder konfigurieren muss, https://forums.servethehome.com/index.php?threads/napp-it-for-proxmox.32368/#post-419886
 
Zuletzt bearbeitet:
Eine incrementelle Replikation erstellt auf dem Quellsystem einen neuen Snap z.B. Snap 101 und überträgt geänderte Datenblöcke zum vorherigen Snap 100.

Auf dem Zielsystem wird dieser Stand Snap 100 benötigt (z.B. für ein Rollback) damit die Übertragung auch hier den Stand von 101 ergibt (Snap 101 wird bei Erfolg angelegt)
Vielen Dank.

Ich hab jetzt viel ausprobiert und noch mal das Manual genauer gelesen. Eigentlich ist es dort klar formuliert, ich habe es bisher nur nicht richtig verstanden bzw. überlesen:

Code:
man zfs-receive
...
-F  Force a rollback of the file system to the most recent snapshot before performing the receive operation. If receiving an incremental replication stream (for example, one generated by zfs send -R [-i|-I]), destroy snapshots and file systems that do not exist on the sending side.

-d  Discard the first element of the sent snapshot's file system name, using the remaining elements to determine the name of the target filesystem for the new snapshot as described in the paragraph above.
-u  File system that is associated with the received stream is not mounted.
...


So wie ich das verstehe ist das -F dafür da, bei inkrementellen Snapshots auf dem ZIEL alle Snapshots wegzuwerfen, die nicht auch auf der QUELLE vorhanden sind, was faktisch bedeutet, dass mein Backup-Volume (ZIEL) nie größer werden kann als das Produktiv-Volume (QUELLE) - also 2TB. Ich brauche also keine 8TB Festplatte sondern kann auch eine 2TB Festplatte nehmen. Folglich muss ich mir auch keine Sorgen machen, dass beim Restore etwas "überläuft". Dann ist das perfekt so, wie es ist, auch wenn ich dann ältere Snapshots verliere, die reichen durch zfs-auto-snapshot lange genug zurück.

Das `-d` ist mir noch nicht so ganz klar, aber das finde ich auch noch heraus.

Mein aktuelles Fazit: Keine Sorge wegen dem Backup, das läuft und überläuft auch nicht. Ein Full-Restore habe ich nun auch erfolgreich durchgeführt-hat bei ca. 1,6TB etwa 7 Std gedauert (bei 3 Datasets und kurzen Pausen zwischen dem wieder herstellen). Das was ich jetzt noch machen will, ist, statt eines pushs (auf die externe USB-Platte) ein pull via ssh zu machen, damit es absolut sicher abläuft und auch bei einer Randomware keine großen Verluste entstehen würden, weil die ja nicht per ssh auf das Zielsystem kommen kann, denn das zieht sich die Backups ja.

Vielen Dank für die Anmerkungen and @gea und @ludwinator
 
@gea
Hätte noch mal ne Frage zu napp-it und den Jobs, gibt es eine Möglichkeit einzelne Jobs (z.B. replication) zu verknüpfen, so dass diese sequentiell ausgeführt werden? Konnte in den Dokus so ad hoc nichts in die Richtung finden.

Eine weitere Verständnisfrage zu den push Alert Jobs, worauf sollten diese reagieren? Auf jegliche Fehler wie bei der Email Alarmierung (sprich Disc, Cap und Jobs)? Konnte zwar test Pushs per webapi erhalten, bei einem testweise fehlerhaft endenden other job kam aber keine Alarmierung per push, obwohl dieser mit error in der job Liste stand. Auto-Job ist aktiv (1min).
 
Hardwareluxx setzt keine externen Werbe- und Tracking-Cookies ein. Auf unserer Webseite finden Sie nur noch Cookies nach berechtigtem Interesse (Art. 6 Abs. 1 Satz 1 lit. f DSGVO) oder eigene funktionelle Cookies. Durch die Nutzung unserer Webseite erklären Sie sich damit einverstanden, dass wir diese Cookies setzen. Mehr Informationen und Möglichkeiten zur Einstellung unserer Cookies finden Sie in unserer Datenschutzerklärung.


Zurück
Oben Unten refresh