ZFS Snapshot progress check

Not sure exactly what you mean, but if you are talking about issuing the "zfs snapshot" command, the snapshot should be created when the command returns.
If you are talking about progress during a zfs send try adding a "-v" or "--verbose"

Like

Reactions: jbo@

rootbert

Reactions: gpw928 and 6502

Erichans

Guys is there a way to check the progress of a snapshot Or any other way to know when it is done?
 Snapshots A snapshot is a read-only copy of a file system or volume. Snapshots can be created extremely quickly, [. ]

So, I'd think when you get a success return value, you're done.

BaronBS

 Snapshots A snapshot is a read-only copy of a file system or volume. Snapshots can be created extremely quickly, [. ]

So, I'd think when you get a success return value, you're done.


So something like this should work as expected?
#!/usr/bin/env bash # Vars _date=`date "+%Y-%m-%d"` _disk_dest="/tmp/bkp" _bkp_dest="$_disk_dest/$_date" _pool="tank1" _snap="zhome@`hostname`_$_date" _hbase="tank1/zhome@base-FreeBaSeD-T430_2023-06-30" # Create directory destination mkdir -p "$/zhome" # Functions bkp_files()< zfs snapshot "$"/"$" && \ zfs send -I "$" \ tank1/"$" | \ xz -9 > /mnt/bkp/"$"/zhome.xz > . 

mer

You're taking a snapshot of your home dataset and zfs send to a file (piping through xz)? If you add "-v" or "--verbose" to the xzf send you can get the progress of how much has been sent to the pipe.
Without dragging out reference stuff I think it should work as long as permissions are correct or you are running as root.
I would try the commands by hand first before tossing them into a script.

Like

Reactions: BaronBS

Eric A. Borisch

So something like this should work as expected?
#!/usr/bin/env bash # Vars _date=`date "+%Y-%m-%d"` _disk_dest="/tmp/bkp" _bkp_dest="$_disk_dest/$_date" _pool="tank1" _snap="home@`hostname`_$_date" _hbase="tank1/zhome@base-FreeBaSeD-T430_2023-06-30" # Create directory destination mkdir -p "$/zhome" # Functions bkp_files()< zfs snapshot "$"/"$" && \ zfs send -I "$" \ tank1/"$" | \ xz -9 > /mnt/bkp/"$"/zhome.xz > . 

Try running it with bash -x to review the built commands, but it looks like your send will be -I tank1/zhome@base… tank1/home@.. ( where zhome!=home, and the send will fail.)

BaronBS

Try running it with bash -x to review the built commands, but it looks like your send will be -I tank1/zhome@base… tank1/home@.. ( where zhome!=home, and the send will fail.)

Thank you, I fixed the var. But my question is regarding the && , if the zfs send would wait for the zfs snapshot to finish in the background first. And I say background because after I run the snapshot command, I usually check with zfs list -t snapshot and the size of the be usually takes a few minutes to reach the real size and stops grow.

Erichans

[. ] But my question is regarding the && , if the zfs send would wait for the zfs snapshot to finish in the background first. And I say background because after I run the snapshot command, I usually check with bectl list and the size of the be usually takes a few minutes to reach the real size and stops grow.

Rich (BB code):
An AND list has the form command1 && command2 command2 is executed if, and only if, command1 returns an exit status of zero (success).

I (not a bash expert) would say that is exactly as intended.

I don't quite understand your "background" remark. After a snapshot creation, bectl list only lists BEs, unless used in conjuction with the -s option—see bectl(8). What is your exact bectl command?

BaronBS

Rich (BB code):
An AND list has the form command1 && command2 command2 is executed if, and only if, command1 returns an exit status of zero (success).

I (not a bash expert) would say that is exactly as intended.

I don't quite understand your "background" remark. After a snapshot creation, bectl list only lists BEs, unless used in conjuction with the -s option—see bectl(8). What is your exact bectl command?

Sorry, I meant zfs list -t snapshot , bectl it is a part of the second half of the sh (out of the scope of this thread).

Eric A. Borisch


Thank you, I fixed the var. But my question is regarding the && , if the zfs send would wait for the zfs snapshot to finish in the background first. And I say background because after I run the snapshot command, I usually check with zfs list -t snapshot and the size of the be usually takes a few minutes to reach the real size and stops grow.


When the snapshot command returns, the snapshot is created and available. It is a very small (fast; not “backgrounded”) operation to create a snapshot in ZFS.

Thanks

Reactions: BaronBS

gpw928

As rootbert suggested, pv is probably the best way to monitor progress of zfs send .

And as Eric A. Borisch posted while I composed this, the snapshot is available immediately. No waiting.

Looking at your scrpt that xz -9 is going to slow things down a lot. Unless absolute maximum compression is required in real time, I'd consider a different approach (write output to a file, then either nohup and background xz , or scan for compression candidates from cron at 2am).

Here's a fragment of the code I use to send a snapshot of my tank to external storage:

EXTSN1=$(GetDiskSerialNumber $EXTDISK1 12) gpart destroy -F $EXTDISK1 gpart create -s gpt $EXTDISK1 gpart add -t freebsd-zfs -l X0:$EXTSN1 $EXTDISK1 zpool create -f offsite /dev/gpt/X0:$EXTSN1 zfs set compression=lz4 offsite zfs snapshot -r tank@replica zfs unmount offsite size=$(zfs send -nP -R tank@replica | grep "^size" | sed -e "s/size[ $TAB]*//") IsPosNZint "$size" || Barf "bad send size for tank@replica1: \"$size\"" zfs send -R tank@replica | pv -s $size -ptebarT | zfs receive -Fdu offsite zfs destroy -r tank@replica zfs list -t snapshot zpool export offsite

There's a few external references, but I think that they are fairly self-explanitory.

It illustrates how you can use zfs send -nP to get an estimate of the volume of data to be sent, and then pv to report on actual progress.

Reactions: BaronBS and smithi

mer

You mean xz ? Yep, typo sorry

Thanks

Reactions: BaronBS

mer

"And I say background because after I run the snapshot command, I usually check with zfs list -t snapshot and the size of the be usually takes a few minutes to reach the real size and stops grow."

I find this odd/interesting. The only reason a snapshot size should change is because blocks are migrating to because the source is changing, at least in my understanding because of the "Copy On Write" behavior.

snapshot something that has say 4 4MB files in it, total of 16MB. The size of the snapshot is relatively small, likely mostly metadata pointing to the original blocks.
If you delete one of those files, the size of the snapshot increases by 4MB (more or less), the current source now has 12MB. Create a new 4MB file, the current source has 16MB, the snapshot still has 4MB plus metadata pointing to the other 12MB that existed when the snapshot was created.

One of the best ways to see this is with Boot Environments. If you have a bunch due to freebsd-upgrades, do bectl list then start doing bectl destroy -o then bectl list and you can see the space migrate around and eventually get reclaimed.

It would be interesting to maybe do the snapshot command on it's own, put it in an if. That way if the zfs snapshot command is successful, you are sure the command has completed, everything inside the if gets executed then you could also add an else to echo an error message.

Thanks

Reactions: BaronBS

Eric A. Borisch

The 'USED' parameter of a snapshot shows the size of the blocks it uniquely references; this will change as the (active) filesystem has blocks modified / freed. See zfsprops(7) and zfsconcepts(7). If no blocks have been modified or released since the snapshot was created, used==0; as blocks are modified/freed in the live filesystem, if this is the only snapshot that captures that state, the used parameter will grow, so it's kind of a hard metric to pin down, as actions on other things (live filesystem, destruction of other snapshots) influences its value.

In terms of the size of data on disk that the snapshot refers to, that's found in the 'REFER' column of zfs list -t snapshots; you'll note that size never changes after creation.

edit: clarification that it is the size of the blocks, not the number of blocks.

Reactions: BaronBS and mer