diff options
author | Renato Botelho <renato@netgate.com> | 2015-08-26 15:12:02 -0300 |
---|---|---|
committer | Renato Botelho <renato@netgate.com> | 2015-08-26 15:12:02 -0300 |
commit | 03b19a93f4d8d870507ee96121cee4acd748dd2a (patch) | |
tree | 71a34e9e7e73d13de21cb4ad831799fb10c30df4 /src/etc/rc.backup_rrd.sh | |
parent | 7f410a121522c5d0e2660256ae50c1fde1df3645 (diff) | |
parent | 30ce58ac1ea27b758d5112cb5a3b190c9760f010 (diff) | |
download | pfsense-03b19a93f4d8d870507ee96121cee4acd748dd2a.zip pfsense-03b19a93f4d8d870507ee96121cee4acd748dd2a.tar.gz |
Merge branch 'master' into bootstrap
Diffstat (limited to 'src/etc/rc.backup_rrd.sh')
-rwxr-xr-x | src/etc/rc.backup_rrd.sh | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/src/etc/rc.backup_rrd.sh b/src/etc/rc.backup_rrd.sh new file mode 100755 index 0000000..c14ffc7 --- /dev/null +++ b/src/etc/rc.backup_rrd.sh @@ -0,0 +1,27 @@ +#!/bin/sh + +: ${RRDDBPATH:=/var/db/rrd} +: ${CF_CONF_PATH:=/cf/conf} + +# Save the rrd databases to the config path. +if [ -d "${RRDDBPATH}" ]; then + [ -z "$NO_REMOUNT" ] && /etc/rc.conf_mount_rw + [ -f "${CF_CONF_PATH}/rrd.tgz" ] && /bin/rm -f "${CF_CONF_PATH}"/rrd.tgz + + tgzlist="" + + for rrdfile in "${RRDDBPATH}"/*.rrd ; do + xmlfile="${rrdfile%.rrd}.xml" + tgzfile="${rrdfile%.rrd}.tgz" + /usr/bin/nice -n20 /usr/local/bin/rrdtool dump "$rrdfile" "$xmlfile" + cd / && /usr/bin/tar -czf "${tgzfile}" -C / "${RRDDBPATH#/}"/*.xml + /bin/rm -f "${RRDDBPATH}"/*.xml + tgzlist="${tgzlist} @${tgzfile}" + done + if [ -n "${tgzlist}" ]; then + cd / && /usr/bin/tar -czf "${CF_CONF_PATH}/rrd.tgz" ${tgzlist} + /bin/rm -f "${RRDDBPATH}"/*.tgz + fi + [ -z "$NO_REMOUNT" ] && /etc/rc.conf_mount_ro +fi + |