mirror of
https://github.com/deajan/osync
synced 2024-11-19 03:25:37 +00:00
150 lines
3.4 KiB
Bash
Executable File
150 lines
3.4 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
PROGRAM="Osync-batch" # Batch program to run osync instances sequentially and rerun failed ones
|
|
AUTHOR="(L) 2013-2014 by Orsiris \"Ozy\" de Jong"
|
|
CONTACT="http://www.netpower.fr/osync - ozy@netpower.fr"
|
|
PROGRAM_BUILD=3003201501
|
|
|
|
## Runs an osync instance for every conf file found
|
|
## If an instance fails, run it again if time permits
|
|
|
|
## Configuration file path. The path where all the osync conf files are, usually /etc/osync
|
|
CONF_FILE_PATH=.
|
|
|
|
## If maximum execution time is not reached, failed instances will be rerun. Max exec time is in seconds. Example is set to 10 hours.
|
|
MAX_EXECUTION_TIME=36000
|
|
|
|
## Max retries specifies the number of reruns an instance may get
|
|
MAX_RETRIES=3
|
|
|
|
|
|
## Osync executable full path can be set here if it cannot be found on the system
|
|
if ! type -p osync.sh > /dev/null 2>&1
|
|
then
|
|
OSYNC_EXECUTABLE=osync.sh
|
|
else
|
|
OSYNC_EXECUTABLE=$(type -p osync.sh)
|
|
fi
|
|
|
|
## Log file path
|
|
if [ -w /var/log ]
|
|
then
|
|
LOG_FILE=/var/log/osync-batch.log
|
|
else
|
|
LOG_FILE=./osync-batch.log
|
|
fi
|
|
|
|
# No need to edit under this line ##############################################################
|
|
|
|
function Log
|
|
{
|
|
prefix="TIME: $SECONDS - "
|
|
echo -e "$prefix$1" >> "$LOG_FILE"
|
|
|
|
if [ $silent -eq 0 ]
|
|
then
|
|
echo -e "$prefix$1"
|
|
fi
|
|
}
|
|
|
|
|
|
function Batch
|
|
{
|
|
## Get list of .conf files
|
|
for i in $(ls $CONF_FILE_PATH/*.conf)
|
|
do
|
|
if [ "$RUN" == "" ]
|
|
then
|
|
RUN="$i"
|
|
else
|
|
RUN=$RUN" $i"
|
|
fi
|
|
done
|
|
|
|
RETRIES=0
|
|
while [ $MAX_EXECUTION_TIME -gt $SECONDS ] && [ "$RUN" != "" ] && [ $MAX_RETRIES -gt $RETRIES ]
|
|
do
|
|
Log "Osync instances will be run for: $RUN"
|
|
for i in $RUN
|
|
do
|
|
$OSYNC_EXECUTABLE $i $opts
|
|
if [ $? != 0 ]
|
|
then
|
|
Log "Run instance $(basename $i) failed"
|
|
if [ "RUN_AGAIN" == "" ]
|
|
then
|
|
RUN_AGAIN="$i"
|
|
else
|
|
RUN_AGAIN=$RUN_AGAIN" $i"
|
|
fi
|
|
elif [ $verbose -eq 1 ]
|
|
then
|
|
Log "Run instance $(basename $i) succeed."
|
|
fi
|
|
done
|
|
RUN="$RUN_AGAIN"
|
|
RUN_AGAIN=""
|
|
RETRIES=$(($RETRIES + 1))
|
|
done
|
|
}
|
|
|
|
function Usage
|
|
{
|
|
echo "$PROGRAM $PROGRAM_BUILD"
|
|
echo $AUTHOR
|
|
echo $CONTACT
|
|
echo ""
|
|
echo "Batch script to sequentially run osync instances and rerun failed ones."
|
|
echo "Usage: osync-batch.sh [OPTIONS]"
|
|
echo ""
|
|
echo "[OPTIONS]"
|
|
echo "--path=/path/to/conf Path to osync conf files, defaults to /etc/osync"
|
|
echo "--max-retries=X Number of retries max for failed instances, defaults to 3"
|
|
echo "--max-exec-time=X Retry failed instances only if max execution time not reached (defaults to 36000 seconds)"
|
|
echo "--dry Will run osync without actually doing anything; just testing"
|
|
echo "--silent Will run osync without any output to stdout, used for cron jobs"
|
|
echo "--verbose Increases output"
|
|
exit 128
|
|
}
|
|
|
|
silent=0
|
|
dry=0
|
|
verbose=0
|
|
opts=""
|
|
for i in "$@"
|
|
do
|
|
case $i in
|
|
--silent)
|
|
silent=1
|
|
opts=$opts" --silent"
|
|
;;
|
|
--dry)
|
|
dry=1
|
|
opts=$opts" --dry"
|
|
;;
|
|
--verbose)
|
|
verbose=1
|
|
opts=$opts" --verbose"
|
|
;;
|
|
--path=*)
|
|
CONF_FILE_PATH=${i##*=}
|
|
;;
|
|
--max-retries=*)
|
|
MAX_RETRIES=${i##*=}
|
|
;;
|
|
--max-exec-time=*)
|
|
MAX_EXECUTION_TIME=${i##*=}
|
|
;;
|
|
--help|-h)
|
|
Usage
|
|
;;
|
|
*)
|
|
Log "Unknown param '$i'"
|
|
Usage
|
|
;;
|
|
esac
|
|
done
|
|
|
|
Log "$(date) Osync batch run"
|
|
Batch
|