From 1a98b469a22c87bb06196270585c820231f9aa57 Mon Sep 17 00:00:00 2001 From: Tim Foster Date: Mon, 25 Aug 2008 14:28:33 +0100 Subject: [PATCH] ## was a bad idea - making // do the right thing instead. --- Changelog | 17 +- README.zfs-auto-snapshot.txt | 18 +- src/lib/svc/method/zfs-auto-snapshot | 168 ++++++++++++------ .../system/filesystem/zfs-auto-snapshot.xml | 21 ++- 4 files changed, 136 insertions(+), 88 deletions(-) diff --git a/Changelog b/Changelog index b28c348..7235c9e 100644 --- a/Changelog +++ b/Changelog @@ -5,19 +5,18 @@ - service start/stop logs stay under /var/svc/log - other logs saved to /export/home/zfssnap (and syslog) * Add a 'zfs/interval' property value 'none' which doesn't use cron -* Add a 'zfs/fs-name' property value '##' * Add a cache of svcprops to the method script -* Add a com.sun:auto-snapshot user property, com.sun:auto-snapshot:$LABEL - takes precedence -* Remove the seconds field of the snapshot name - we don't really need it -* Make recursive snapshots the default for bundled '//' manifests -* Changed the way // works with recursive snapshots - (look for local props only when using -r) +* Add a com.sun:auto-snapshot user property used by all instances, + com.sun:auto-snapshot:$LABEL takes precedence +* Remove the seconds field of the snapshot name - it's not needed +* Changed the way // works with recursive snapshots - ignore + snapshot-children, and instead automatically determine when we can take + recursive snapshots based on which datasets have the zfs user properties * Set avoidscrub to false by default (bug was fixed in in nv_94) * Bugfix from Dan - Volumes are datasets too * Automatically snapshot everything by setting com.sun:auto-snapshot=true - on startup. (this gets done on all root pools - existing properties set - to false will override this) + on startup. (this gets done on all top level datasets - an existing + property set to false on the top level dataset overrides this) * Check for missed snapshots on startup * Clean up shell style * Clean up preremove script diff --git a/README.zfs-auto-snapshot.txt b/README.zfs-auto-snapshot.txt index 28179b3..375961e 100644 --- a/README.zfs-auto-snapshot.txt +++ b/README.zfs-auto-snapshot.txt @@ -63,17 +63,10 @@ The properties each instance needs are: # zfs set com.sun:auto-snapshot:frequent=true tank/timf - When the "snap-children" property is set to "true", - only locally-set dataset properties are used to - determine which filesystems to snapshot - - property inheritance is not respected in this case, - but yeilds better performance for large dataset trees. - - The special filesystem name "##" is the reverse of the - above - it snapshots all filesystems, except ones that are - explicitly marked with a "com.sun:auto-snapshot: