aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog6
-rw-r--r--configure.in2
-rw-r--r--handlers/rsync.in55
3 files changed, 38 insertions, 25 deletions
diff --git a/ChangeLog b/ChangeLog
index dd8f605..7eb37d6 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,4 +1,4 @@
-version 0.9.8 -- UNRELEASED
+version 0.9.8 -- September 12, 2010
backupninja changes
. Added GZIP_OPTS option, defaulting to --rsyncable, so that this
option can be disabled on systems that don't support it. This
@@ -27,6 +27,10 @@ version 0.9.8 -- UNRELEASED
(Closes: #587011)
. Fix code logic to make dbusername/dbpassword actually usable
(Closes Redmine bug #2264)
+ rsync:
+ . Fix lockfile checks. This prevents multiple instances of the same
+ rsync job to run in parallel.
+ . Avoid passing the remote user twice to rsync-over-ssh.
doc changes
manpage:
. Fix typo in manpage (Closes: #583778)
diff --git a/configure.in b/configure.in
index da2d6ba..59ccd10 100644
--- a/configure.in
+++ b/configure.in
@@ -3,7 +3,7 @@
# The maintainer mode is causing me grief with newest versions of autotools
#AM_MAINTAINER_MODE
-AC_INIT([backupninja],[0.9.7],[backupninja@lists.riseup.net])
+AC_INIT([backupninja],[0.9.8],[backupninja@lists.riseup.net])
AC_CONFIG_SRCDIR([src/backupninja.in])
AM_INIT_AUTOMAKE
diff --git a/handlers/rsync.in b/handlers/rsync.in
index 8f638d7..fea7e7b 100644
--- a/handlers/rsync.in
+++ b/handlers/rsync.in
@@ -101,22 +101,6 @@
# You dont need to manually specify vservers using "include = /vservers".
# They are automatically backuped if vserver is set to "yes" on you backupninja.conf.
#
-# Changelog
-# ---------
-#
-# 20090329 - rhatto at riseup.net
-#
-# - Added support for:
-# - Remote destinations
-# - Long rotation format similar to maildir handler
-# - Batch files through --read-batch and --write-batch
-# - Custom file list using --files-from
-# - SSH persistent connection using ControlMaster
-# - The rsync:// protocol
-# - Metadata folder for each backup folder
-# - General refactoring
-# - Code cleanup
-#
# function definitions
@@ -279,7 +263,8 @@ function eval_config {
nice=""
fi
- ssh_cmd="ssh -T -o PasswordAuthentication=no $host -p $port -l $user -i $id_file"
+ ssh_cmd_base="ssh -T -o PasswordAuthentication=no -p $port -i $id_file"
+ ssh_cmd="$ssh_cmd_base $user@$host"
if [ "$from" == "remote" ] || [ "$dest" == "remote" ]; then
if [ "$testconnect" == "yes" ] && [ "$protocol" == "ssh" ]; then
@@ -846,7 +831,12 @@ function test_connect {
function set_lockfile {
if [ ! -z "$lockfile" ]; then
- $touch $lockfile || warning "Could not create lockfile $lockfile"
+ mkdir -p `dirname $lockfile`
+ if ( set -o noclobber; echo "$$" > "$lockfile" ) &> /dev/null; then
+ trap 'unset_lockfile' INT TERM EXIT
+ else
+ fatal "Could not create lockfile $lockfile, exiting"
+ fi
fi
}
@@ -854,7 +844,25 @@ function set_lockfile {
function unset_lockfile {
if [ ! -z "$lockfile" ]; then
- $rm $lockfile || warning "Could not remove lockfile $lockfile"
+ $rm -f $lockfile || warning "Could not remove lockfile $lockfile"
+ fi
+
+}
+
+function check_lockfile {
+
+ local pid process
+
+ if [ ! -z "$lockfile" ] && [ -f "$lockfile" ]; then
+ pid="`cat $lockfile`"
+ process="`ps --no-headers -o comm $pid`"
+ if [ "$?" == "0" ] && [ "`ps --no-headers -o comm $$`" == "$process" ]; then
+ info "Another backup is running for $lockfile, skipping run"
+ exit
+ else
+ info "Found old lockfile $lockfile, removing it"
+ unset_lockfile
+ fi
fi
}
@@ -911,9 +919,9 @@ function set_rsync_options {
fatal "SSH Identity file $id_file not found"
exit 1
else
- debug RSYNC_RSH=\"$ssh_cmd\"
- echo RSYNC_RSH=\"$ssh_cmd\" >> $log
- RSYNC_RSH="$ssh_cmd"
+ debug RSYNC_RSH=\"$ssh_cmd_base\"
+ echo RSYNC_RSH=\"$ssh_cmd_base\" >> $log
+ export RSYNC_RSH="$ssh_cmd_base"
fi
fi
@@ -1044,6 +1052,7 @@ function end_mux {
# the backup procedure
eval_config
+check_lockfile
set_lockfile
set_rsync_options
start_mux
@@ -1062,7 +1071,7 @@ for SECTION in $include; do
info "Syncing $SECTION on $dest_path..."
debug $nice $rsync "${rsync_options[@]}" $filelist_flag $excludes $batch_option $orig $dest_path
- $nice $rsync "${rsync_options[@]}" $filelist_flag $excludes $batch_option $orig $dest_path >> $log
+ $nice $rsync "${rsync_options[@]}" $filelist_flag $excludes $batch_option $orig $dest_path | tee -a $log
if [ "$?" != "0" ]; then
warning "Rsync error when trying to transfer $SECTION"