Adding the 'none' interval, and having the Makefile generate PSTAMPS

This commit is contained in:
Tim Foster 2008-07-31 10:48:56 +01:00
parent f223b7e139
commit ae57266595
4 changed files with 43 additions and 16 deletions

View File

@ -1,5 +1,6 @@
pkg: clean pkg: clean
mkdir -p proto mkdir -p proto
cat `pwd`/src/pkginfo.s | sed -e s/~PSTAMP~/`uname -n``date +%Y%m%d%H%M%S`/g > `pwd`/src/pkginfo
pkgmk -f `pwd`/src/prototype -d `pwd`/proto -r `pwd`/src pkgmk -f `pwd`/src/prototype -d `pwd`/proto -r `pwd`/src
clean: clean:

View File

@ -67,7 +67,11 @@ The properties each instance needs are:
determine which filesystems to snapshot - determine which filesystems to snapshot -
property inheritance is not respected. property inheritance is not respected.
zfs/interval [ hours | days | months ] zfs/interval [ hours | days | months | none]
When set to none, we don't take automatic snapshots, but
leave an SMF instance available for users to manually
fire the method script whenever they want - useful for
snapshotting on system events.
zfs/keep How many snapshots to retain. "all" keeps all snapshots. zfs/keep How many snapshots to retain. "all" keeps all snapshots.

View File

@ -77,21 +77,31 @@ LOG=""
HAS_RECURSIVE=$(zfs snapshot 2>&1 | fgrep -e '-r') HAS_RECURSIVE=$(zfs snapshot 2>&1 | fgrep -e '-r')
function get_pair {
NAME=$1
shift 2
echo "${NAME}=\"$@\""
echo "export ${NAME}"
}
# A function to pull in the variables from the FMRI given # A function to pull in the variables from the FMRI given
# as the first argument. # as the first argument.
function zfs_smf_props { function zfs_smf_props {
SMF_PROPS=$(svcprop -p zfs $1 | \ IFS="
sed -e 's#^zfs/fs-name#zfs/fs_name#g' \ "
-e 's#^zfs/backup-lock#zfs/backup_lock#g' \ SMF_PROPS="$(svcprop -t -p zfs $1 |\
-e 's#^zfs/snapshot-children#zfs/snapshot_children#g' \ sed -e 's#zfs/fs-name#zfs/fs_name#g' \
-e 's#^zfs/backup-save-cmd#zfs/backup_save_cmd#g' \ -e 's#zfs/backup-lock#zfs/backup_lock#g' \
-e 's#zfs/##g' |\ -e 's#zfs/snapshot-children#zfs/snapshot_children#g' \
awk '{printf("%s=%s ",$1,$3)}') -e 's#zfs/backup-save-cmd#zfs/backup_save_cmd#g' \
-e 's#zfs/##g' -e 's/$/,/g')"
for pair in $SMF_PROPS ; do IFS=,
export "$pair" for line in $SMF_PROPS ; do
done IFS='
'
eval $(get_pair $line)
done
} }
@ -186,6 +196,10 @@ function add_cron_job { # $INTERVAL $PERIOD $OFFSET $FMRI
TIMES=$(get_divisor 1 12 $PERIOD) TIMES=$(get_divisor 1 12 $PERIOD)
ENTRY="0 0 1 $TIMES *" ENTRY="0 0 1 $TIMES *"
;; ;;
'none')
return 0
;;
esac esac
# Since we may have multiple instances all trying to start at # Since we may have multiple instances all trying to start at
@ -231,6 +245,12 @@ function add_cron_job { # $INTERVAL $PERIOD $OFFSET $FMRI
function unschedule_snapshots { function unschedule_snapshots {
typeset FMRI=$1 typeset FMRI=$1
typeset INTERVAL=$interval
# interval set to 'none' means we don't want cron jobs
if [ "$INTERVAL" == "none" ]; then
return 0
fi
# See notes on $LOCK_OWNED variable in function add_cron_job # See notes on $LOCK_OWNED variable in function add_cron_job
LOCK_OWNED="false" LOCK_OWNED="false"
@ -269,6 +289,7 @@ function take_snapshot {
FMRI=$1 FMRI=$1
zfs_smf_props $FMRI zfs_smf_props $FMRI
export LOG=$log
typeset DATE=$(date +%F-%H${SEP}%M${SEP}%S) typeset DATE=$(date +%F-%H${SEP}%M${SEP}%S)
typeset FILESYS=$fs_name typeset FILESYS=$fs_name
typeset KEEP=$keep typeset KEEP=$keep
@ -649,13 +670,14 @@ function is_scrubbing { # POOL SCRUBLIST
# created above, where the argument is the FMRI containing properties we can # created above, where the argument is the FMRI containing properties we can
# consult to in order to actually take the snapshot. # consult to in order to actually take the snapshot.
zfs_smf_props $SMF_FMRI if [ -n "${SMF_FMRI}" ] ; then
export LOG=$(svcprop -p restarter/logfile $SMF_FMRI) zfs_smf_props $SMF_FRI
export LOG=${log}
fi
# $1 start | stop | an FMRI that we want to take snapshots of. # $1 start | stop | an FMRI that we want to take snapshots of.
case "$1" in case "$1" in
'start') 'start')
schedule_snapshots $SMF_FMRI schedule_snapshots $SMF_FMRI
if [ $? -eq 0 ] ; then if [ $? -eq 0 ] ; then
result=$SMF_EXIT_OK result=$SMF_EXIT_OK

View File

@ -13,7 +13,7 @@ VERSION=0.11
MAXINST=1 MAXINST=1
CATEGORY=application CATEGORY=application
DESC=Takes automatic snapshots of ZFS filesystems on a periodic basis. DESC=Takes automatic snapshots of ZFS filesystems on a periodic basis.
PSTAMP=haiiro20080122113401 PSTAMP=haiiro20080730110036
VENDOR=Sun Microsystems, Inc. VENDOR=Sun Microsystems, Inc.
HOTLINE=Please contact your local service provider HOTLINE=Please contact your local service provider
EMAIL=tim.foster@sun.com EMAIL=tim.foster@sun.com