forked from extern/zfs-auto-snapshot
Compare commits
45 Commits
upstream/1
...
master
Author | SHA1 | Date | |
---|---|---|---|
92db087bb0 | |||
f938d9cc1c | |||
4538217932 | |||
99e1a6103d | |||
86a95095ee | |||
363a847ee3 | |||
12945110d3 | |||
d5646c901e | |||
4a59d0d615 | |||
ef7ae674f5 | |||
b0a5909335 | |||
3689b2c43d | |||
d27bbfa650 | |||
897ca026e1 | |||
3e48c8956e | |||
3efc478828 | |||
c99de67c63 | |||
4425d681f3 | |||
6f6d1202cf | |||
6ee4553cf6 | |||
6c7da10e24 | |||
3d9992b086 | |||
f145cf6e07 | |||
838b03b41f | |||
e1268767b8 | |||
e93096c2d9 | |||
1ae1adc5f0 | |||
41eddc97cc | |||
2b7b694a95 | |||
277287f824 | |||
d49be6a2de | |||
2e1f309131 | |||
1666623191 | |||
739972f18a | |||
8c45add2c0 | |||
9c6f065589 | |||
62f5f7d920 | |||
b74769894c | |||
11130ba8d6 | |||
27413ac798 | |||
c4ad5eeac5 | |||
6e32b25d8f | |||
b2e97c5fe0 | |||
d3bdd2dc23 | |||
f2767ad43a |
9
CHANGELOG
Normal file
9
CHANGELOG
Normal file
@ -0,0 +1,9 @@
|
||||
[ 1.2.5 (Unreleased) ]
|
||||
|
||||
* Start a changelog
|
||||
* Accept PR#94 from aimileus/macos
|
||||
- Replace --utc longform option with -u for macos compatibility
|
||||
* Accept PR#107 from ArakniD/master
|
||||
- Add optional label for snap removals
|
||||
|
||||
-- Jonathan Carter 2019-09-25, 15:24 SAST
|
11
Makefile
11
Makefile
@ -14,6 +14,15 @@ install:
|
||||
install etc/zfs-auto-snapshot.cron.weekly $(DESTDIR)/etc/cron.weekly/zfs-auto-snapshot
|
||||
install etc/zfs-auto-snapshot.cron.monthly $(DESTDIR)/etc/cron.monthly/zfs-auto-snapshot
|
||||
install -d $(DESTDIR)$(PREFIX)/share/man/man8
|
||||
install src/zfs-auto-snapshot.8 $(DESTDIR)$(PREFIX)/share/man/man8/zfs-auto-snapshot.8
|
||||
install -m 0644 src/zfs-auto-snapshot.8 $(DESTDIR)$(PREFIX)/share/man/man8/zfs-auto-snapshot.8
|
||||
install -d $(DESTDIR)$(PREFIX)/sbin
|
||||
install src/zfs-auto-snapshot.sh $(DESTDIR)$(PREFIX)/sbin/zfs-auto-snapshot
|
||||
|
||||
uninstall:
|
||||
rm $(DESTDIR)/etc/cron.d/zfs-auto-snapshot
|
||||
rm $(DESTDIR)/etc/cron.hourly/zfs-auto-snapshot
|
||||
rm $(DESTDIR)/etc/cron.daily/zfs-auto-snapshot
|
||||
rm $(DESTDIR)/etc/cron.weekly/zfs-auto-snapshot
|
||||
rm $(DESTDIR)/etc/cron.monthly/zfs-auto-snapshot
|
||||
rm $(DESTDIR)$(PREFIX)/share/man/man8/zfs-auto-snapshot.8
|
||||
rm $(DESTDIR)$(PREFIX)/sbin/zfs-auto-snapshot
|
||||
|
6
README
6
README
@ -15,7 +15,7 @@ the zfs utilities and cron, and can run in the dash shell.
|
||||
Installation:
|
||||
-------------
|
||||
|
||||
wget https://github.com/zfsonlinux/zfs-auto-snapshot/archive/master.zip
|
||||
unzip master.zip
|
||||
cd zfs-auto-snapshot-master
|
||||
wget https://github.com/zfsonlinux/zfs-auto-snapshot/archive/upstream/1.2.4.tar.gz
|
||||
tar -xzf 1.2.4.tar.gz
|
||||
cd zfs-auto-snapshot-upstream-1.2.4
|
||||
make install
|
||||
|
100
debian/changelog
vendored
100
debian/changelog
vendored
@ -1,100 +0,0 @@
|
||||
zfs-auto-snapshot (1.2.0-1) unstable; urgency=low
|
||||
|
||||
[ Roland Stühmer ]
|
||||
* Fix SNAPNAME to contain the DATE if label is empty
|
||||
|
||||
[ Borut Mrak ]
|
||||
* Remove PREFIX from cron scripts - they should always end up in /etc.
|
||||
* Leave PREFIX for man page and program, and set it to /usr/local by default.
|
||||
|
||||
[ Maciej Małecki ]
|
||||
* Add `--{pre,post}-snapshot` for pre and post creation hook
|
||||
* Abort if pre snapshot hook returns non-zero
|
||||
* Document `--{pre,post}-snapshot
|
||||
|
||||
[ Mike Baynton ]
|
||||
* Make --{pre,post}-snapshot optional, add --destroy-only, revise docs
|
||||
|
||||
[ virtualguy ]
|
||||
* Update README
|
||||
|
||||
[ Darik Horn ]
|
||||
* Install the cron.d part without the execute bit.
|
||||
* Update debian/rules for Makefile changes.
|
||||
|
||||
-- Darik Horn <dajhorn@vanadac.com> Mon, 13 Oct 2014 23:17:30 -0500
|
||||
|
||||
zfs-auto-snapshot (1.1.0-0ubuntu1) unstable; urgency=low
|
||||
|
||||
[ Markus Heberling ]
|
||||
* Use only name property for zfs list
|
||||
|
||||
[ Darik Horn ]
|
||||
* Add a switch for the fast zfs list invocation.
|
||||
|
||||
[ Mike Swanson ]
|
||||
* Add a manpage
|
||||
* Update Makefile for the manual page
|
||||
|
||||
[ HawkOwl ]
|
||||
* Set the snapshots to use UTC time, which makes the date/time display correctly in Windows 7 Previous Versions.
|
||||
|
||||
-- Darik Horn <dajhorn@vanadac.com> Mon, 31 Mar 2014 01:48:58 -0500
|
||||
|
||||
zfs-auto-snapshot (1.0.8-0ubuntu2) unstable; urgency=low
|
||||
|
||||
* Update the debian/control file.
|
||||
|
||||
-- Darik Horn <dajhorn@vanadac.com> Sun, 31 Mar 2013 23:10:55 -0500
|
||||
|
||||
zfs-auto-snapshot (1.0.8-0ubuntu1) unstable; urgency=low
|
||||
|
||||
* Update the README file to be more descriptive.
|
||||
* Fix pool exclusions.
|
||||
|
||||
-- Darik Horn <dajhorn@vanadac.com> Sat, 21 Jan 2012 16:37:28 -0600
|
||||
|
||||
zfs-auto-snapshot (1.0.7-0ubuntu1) unstable; urgency=low
|
||||
|
||||
[ Darik Horn ]
|
||||
* Change objects to datasets in help and comments.
|
||||
* Set keep=8 in the weekly cron job.
|
||||
|
||||
[ Ulrich Petri ]
|
||||
* Fixed --prefix and --sep regexes
|
||||
|
||||
-- Darik Horn <dajhorn@vanadac.com> Wed, 28 Dec 2011 13:30:02 -0600
|
||||
|
||||
zfs-auto-snapshot (1.0.6-0ubuntu1) unstable; urgency=low
|
||||
|
||||
* Remove redundant lines in the cron.d file.
|
||||
* Fix the hourly-daily transposition in the Makefile.
|
||||
|
||||
-- Darik Horn <dajhorn@vanadac.com> Mon, 28 Nov 2011 00:10:05 -0600
|
||||
|
||||
zfs-auto-snapshot (1.0.5-0ubuntu1) unstable; urgency=low
|
||||
|
||||
* Split the cron file for anacron compatibilty.
|
||||
|
||||
-- Darik Horn <dajhorn@vanadac.com> Fri, 25 Nov 2011 14:28:07 -0600
|
||||
|
||||
zfs-auto-snapshot (1.0.4-0ubuntu1) unstable; urgency=low
|
||||
|
||||
* Invert the --skip-scrub test.
|
||||
* Fold the main loops into a do_snapshots function.
|
||||
* Consistently quote literal strings.
|
||||
* Implement --prefix parameter checking.
|
||||
* Rebase exit codes to above 127.
|
||||
* Implement the --event option for :auto-snap-desc.
|
||||
|
||||
-- Darik Horn <dajhorn@vanadac.com> Wed, 23 Nov 2011 10:49:14 -0600
|
||||
|
||||
zfs-auto-snapshot (1.0.3-0ubuntu1) unstable; urgency=low
|
||||
|
||||
* Add -q to the getopt list of short options.
|
||||
* Add an explicit `exit 0` to the end of the script.
|
||||
* Add gbp.conf file for git-buildpackage.
|
||||
* Expand the options variable in the cron part file.
|
||||
* Initial debian packaging.
|
||||
|
||||
-- Darik Horn <dajhorn@vanadac.com> Mon, 21 Nov 2011 21:52:11 -0600
|
1
debian/compat
vendored
1
debian/compat
vendored
@ -1 +0,0 @@
|
||||
7
|
16
debian/control
vendored
16
debian/control
vendored
@ -1,16 +0,0 @@
|
||||
Source: zfs-auto-snapshot
|
||||
Section: admin
|
||||
Priority: extra
|
||||
Maintainer: Darik Horn <dajhorn@vanadac.com>
|
||||
Build-Depends: debhelper (>= 8)
|
||||
Standards-Version: 3.9.4
|
||||
Homepage: http://www.zfsonlinux.org/
|
||||
Vcs-Git: git://github.com/zfsonlinux/zfs-auto-snapshot.git
|
||||
Vcs-Browser: https://github.com/zfsonlinux/zfs-auto-snapshot/
|
||||
|
||||
Package: zfs-auto-snapshot
|
||||
Architecture: all
|
||||
Depends: ${misc:Depends}, cron, zfsutils
|
||||
Description: ZFS Automatic Snapshot Service
|
||||
Automatically create and destroy ZFS snapshots on an hourly, daily, weekly
|
||||
and monthly schedule.
|
1
debian/copyright
vendored
1
debian/copyright
vendored
@ -1 +0,0 @@
|
||||
Copyright 2011 Darik Horn <dajhorn@vanadac.com>
|
3
debian/gbp.conf
vendored
3
debian/gbp.conf
vendored
@ -1,3 +0,0 @@
|
||||
[DEFAULT]
|
||||
upstream-branch = master
|
||||
debian-branch = debian
|
7
debian/rules
vendored
7
debian/rules
vendored
@ -1,7 +0,0 @@
|
||||
#!/usr/bin/make -f
|
||||
|
||||
%:
|
||||
dh $@
|
||||
|
||||
override_dh_auto_install:
|
||||
dh_auto_install -- PREFIX=/usr
|
2
debian/watch
vendored
2
debian/watch
vendored
@ -1,2 +0,0 @@
|
||||
version=3
|
||||
http://githubredir.debian.net/github/dajhorn/zfs-auto-snapshot/([\d\.].*).tar.gz
|
@ -1,2 +1,6 @@
|
||||
#!/bin/sh
|
||||
|
||||
# Only call zfs-auto-snapshot if it's available
|
||||
which zfs-auto-snapshot > /dev/null || exit 0
|
||||
|
||||
exec zfs-auto-snapshot --quiet --syslog --label=daily --keep=31 //
|
||||
|
@ -1,3 +1,3 @@
|
||||
PATH="/usr/bin:/bin:/usr/sbin:/sbin"
|
||||
PATH="/usr/bin:/bin:/usr/local/sbin:/usr/sbin:/sbin"
|
||||
|
||||
*/15 * * * * root zfs-auto-snapshot -q -g --label=frequent --keep=4 //
|
||||
*/15 * * * * root which zfs-auto-snapshot > /dev/null || exit 0 ; zfs-auto-snapshot --quiet --syslog --label=frequent --keep=4 //
|
||||
|
@ -1,2 +1,6 @@
|
||||
#!/bin/sh
|
||||
|
||||
# Only call zfs-auto-snapshot if it's available
|
||||
which zfs-auto-snapshot > /dev/null || exit 0
|
||||
|
||||
exec zfs-auto-snapshot --quiet --syslog --label=hourly --keep=24 //
|
||||
|
@ -1,2 +1,6 @@
|
||||
#!/bin/sh
|
||||
|
||||
# Only call zfs-auto-snapshot if it's available
|
||||
which zfs-auto-snapshot > /dev/null || exit 0
|
||||
|
||||
exec zfs-auto-snapshot --quiet --syslog --label=monthly --keep=12 //
|
||||
|
@ -1,2 +1,6 @@
|
||||
#!/bin/sh
|
||||
|
||||
# Only call zfs-auto-snapshot if it's available
|
||||
which zfs-auto-snapshot > /dev/null || exit 0
|
||||
|
||||
exec zfs-auto-snapshot --quiet --syslog --label=weekly --keep=8 //
|
||||
|
@ -78,7 +78,7 @@ It is passed the dataset and snapshot name.
|
||||
Do not create new snapshots, but do destroy older
|
||||
snapshots. Has no effect unless used with \fB\-k\fR.
|
||||
.IP
|
||||
A non-obvious use may be constructon of cron jobs or
|
||||
A non-obvious use may be construction of cron jobs or
|
||||
scripts that run pre-snapshot command(s), then run
|
||||
zfs-auto-snapshot (without \fB\-k\fR) to quickly
|
||||
snapshot all datasets, then run post-snapshot
|
||||
|
79
src/zfs-auto-snapshot.sh
Executable file → Normal file
79
src/zfs-auto-snapshot.sh
Executable file → Normal file
@ -42,6 +42,7 @@ opt_verbose=''
|
||||
opt_pre_snapshot=''
|
||||
opt_post_snapshot=''
|
||||
opt_do_snapshots=1
|
||||
opt_min_size=0
|
||||
|
||||
# Global summary statistics.
|
||||
DESTRUCTION_COUNT='0'
|
||||
@ -110,7 +111,7 @@ print_log () # level, message, ...
|
||||
;;
|
||||
(inf*)
|
||||
# test -n "$opt_syslog" && logger -t "$opt_prefix" -p daemon.info $*
|
||||
test -n "$opt_verbose" && echo $*
|
||||
test -z "$opt_quiet" && test -n "$opt_verbose" && echo $*
|
||||
;;
|
||||
(deb*)
|
||||
# test -n "$opt_syslog" && logger -t "$opt_prefix" -p daemon.debug $*
|
||||
@ -161,7 +162,23 @@ do_snapshots () # properties, flags, snapname, oldglob, [targets...]
|
||||
|
||||
for ii in $TARGETS
|
||||
do
|
||||
if [ -n "$opt_do_snapshots" ]
|
||||
# Check if size check is > 0
|
||||
size_check_skip=0
|
||||
if [ "$opt_min_size" -gt 0 ]
|
||||
then
|
||||
bytes_written=`zfs get -Hp -o value written $ii`
|
||||
kb_written=$(( $bytes_written / 1024 ))
|
||||
if [ "$kb_written" -lt "$opt_min_size" ]
|
||||
then
|
||||
size_check_skip=1
|
||||
if [ $opt_verbose -gt 0 ]
|
||||
then
|
||||
echo "Skipping target $ii, only $kb_written kB written since last snap. opt_min_size is $opt_min_size"
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ -n "$opt_do_snapshots" -a "$size_check_skip" -eq 0 ]
|
||||
then
|
||||
if [ "$opt_pre_snapshot" != "" ]
|
||||
then
|
||||
@ -191,7 +208,7 @@ do_snapshots () # properties, flags, snapname, oldglob, [targets...]
|
||||
KEEP=$(( $KEEP - 1 ))
|
||||
if [ "$KEEP" -le '0' ]
|
||||
then
|
||||
if do_run "zfs destroy $FLAGS '$jj'"
|
||||
if do_run "zfs destroy -d $FLAGS '$jj'"
|
||||
then
|
||||
DESTRUCTION_COUNT=$(( $DESTRUCTION_COUNT + 1 ))
|
||||
else
|
||||
@ -207,12 +224,19 @@ do_snapshots () # properties, flags, snapname, oldglob, [targets...]
|
||||
# main ()
|
||||
# {
|
||||
|
||||
GETOPT=$(getopt \
|
||||
if [ "$(uname)" = "Darwin" ]; then
|
||||
GETOPT_BIN="$(brew --prefix gnu-getopt 2> /dev/null || echo /usr/local)/bin/getopt"
|
||||
else
|
||||
GETOPT_BIN="getopt"
|
||||
fi
|
||||
|
||||
GETOPT=$($GETOPT_BIN \
|
||||
--longoptions=default-exclude,dry-run,fast,skip-scrub,recursive \
|
||||
--longoptions=event:,keep:,label:,prefix:,sep: \
|
||||
--longoptions=debug,help,quiet,syslog,verbose \
|
||||
--longoptions=pre-snapshot:,post-snapshot:,destroy-only \
|
||||
--options=dnshe:l:k:p:rs:qgv \
|
||||
--longoptions=min-size: \
|
||||
--options=dnshe:l:k:p:rs:qgvm: \
|
||||
-- "$@" ) \
|
||||
|| exit 128
|
||||
|
||||
@ -271,6 +295,10 @@ do
|
||||
opt_label="$2"
|
||||
shift 2
|
||||
;;
|
||||
(-m|--min-size)
|
||||
opt_min_size="$2"
|
||||
shift 2
|
||||
;;
|
||||
(-p|--prefix)
|
||||
opt_prefix="$2"
|
||||
while test "${#opt_prefix}" -gt '0'
|
||||
@ -367,16 +395,33 @@ fi
|
||||
ZPOOL_STATUS=$(env LC_ALL=C zpool status 2>&1 ) \
|
||||
|| { print_log error "zpool status $?: $ZPOOL_STATUS"; exit 135; }
|
||||
|
||||
|
||||
ZFS_LIST=$(env LC_ALL=C zfs list -H -t filesystem,volume -s name \
|
||||
-o name,com.sun:auto-snapshot,com.sun:auto-snapshot:"$opt_label") \
|
||||
|| { print_log error "zfs list $?: $ZFS_LIST"; exit 136; }
|
||||
|
||||
if [ -n "$opt_fast_zfs_list" ]
|
||||
then
|
||||
SNAPSHOTS_OLD=$(env LC_ALL=C zfs list -H -t snapshot -o name -s name|grep $opt_prefix |awk '{ print substr( $0, length($0) - 14, length($0) ) " " $0}' |sort -r -k1,1 -k2,2|awk '{ print substr( $0, 17, length($0) )}') \
|
||||
|| { print_log error "zfs list $?: $SNAPSHOTS_OLD"; exit 137; }
|
||||
# Check if a snapshot label is being used, in which case restrict the old
|
||||
# snapshot removal to only snapshots with the same label format
|
||||
if [ -n "$opt_label" ]
|
||||
then
|
||||
SNAPSHOTS_OLD=$(env LC_ALL=C zfs list -H -t snapshot -o name -s name | \
|
||||
grep "$opt_prefix"_"$opt_label" | \
|
||||
awk '{ print substr( $0, length($0) - 14, length($0) ) " " $0}' | \
|
||||
sort -r -k1,1 -k2,2 | \
|
||||
awk '{ print substr( $0, 17, length($0) )}') \
|
||||
|| { print_log error "zfs list $?: $SNAPSHOTS_OLD"; exit 137; }
|
||||
else
|
||||
SNAPSHOTS_OLD=$(env LC_ALL=C zfs list -H -t snapshot -o name -s name | \
|
||||
grep $opt_prefix | \
|
||||
awk '{ print substr( $0, length($0) - 14, length($0) ) " " $0}' | \
|
||||
sort -r -k1,1 -k2,2 | \
|
||||
awk '{ print substr( $0, 17, length($0) )}') \
|
||||
|| { print_log error "zfs list $?: $SNAPSHOTS_OLD"; exit 137; }
|
||||
fi
|
||||
else
|
||||
SNAPSHOTS_OLD=$(env LC_ALL=C zfs list -H -t snapshot -S creation -o name) \
|
||||
SNAPSHOTS_OLD=$(env LC_ALL=C zfs list -H -t snapshot -S creation -o name) \
|
||||
|| { print_log error "zfs list $?: $SNAPSHOTS_OLD"; exit 137; }
|
||||
fi
|
||||
|
||||
@ -436,11 +481,20 @@ do
|
||||
# Just testing "$ii" != ${ii#$jj} would incorrectly match.
|
||||
iii="$ii/"
|
||||
|
||||
# Exclude datasets that are not named on the command line.
|
||||
|
||||
# Exclude datasets
|
||||
# * that are not named on the command line or
|
||||
# * those whose prefix is not on the command line (if --recursive flag is set)
|
||||
IN_ARGS='0'
|
||||
for jj in "$@"
|
||||
do
|
||||
# Ibid regarding iii.
|
||||
jjj="$jj/"
|
||||
|
||||
if [ "$jj" = '//' -o "$jj" = "$ii" ]
|
||||
then
|
||||
IN_ARGS=$(( $IN_ARGS + 1 ))
|
||||
elif [ -n "$opt_recursive" -a "$iii" != "${iii#$jjj}" ]
|
||||
then
|
||||
IN_ARGS=$(( $IN_ARGS + 1 ))
|
||||
fi
|
||||
@ -530,13 +584,14 @@ SNAPPROP="-o com.sun:auto-snapshot-desc='$opt_event'"
|
||||
|
||||
# ISO style date; fifteen characters: YYYY-MM-DD-HHMM
|
||||
# On Solaris %H%M expands to 12h34.
|
||||
DATE=$(date --utc +%F-%H%M)
|
||||
# We use the shortfirm -u here because --utc is not supported on macos.
|
||||
DATE=$(date -u +%F-%H%M)
|
||||
|
||||
# The snapshot name after the @ symbol.
|
||||
SNAPNAME="$opt_prefix${opt_label:+$opt_sep$opt_label}-$DATE"
|
||||
SNAPNAME="${opt_prefix:+$opt_prefix$opt_sep}${opt_label:+$opt_label}-$DATE"
|
||||
|
||||
# The expression for matching old snapshots. -YYYY-MM-DD-HHMM
|
||||
SNAPGLOB="$opt_prefix${opt_label:+?$opt_label}????????????????"
|
||||
SNAPGLOB="${opt_prefix:+$opt_prefix$opt_sep}${opt_label:+$opt_label}-???????????????"
|
||||
|
||||
if [ -n "$opt_do_snapshots" ]
|
||||
then
|
||||
|
Reference in New Issue
Block a user