mirror of https://gitlab.com/qemu-project/qemu
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
62 lines
1.9 KiB
Bash
62 lines
1.9 KiB
Bash
#!/bin/sh
|
|
|
|
# This script is executed when a guest agent receives fsfreeze-freeze and
|
|
# fsfreeze-thaw command, if it is specified in --fsfreeze-hook (-F)
|
|
# option of qemu-ga or placed in default path (/etc/qemu/fsfreeze-hook).
|
|
# When the agent receives fsfreeze-freeze request, this script is issued with
|
|
# "freeze" argument before the filesystem is frozen. And for fsfreeze-thaw
|
|
# request, it is issued with "thaw" argument after filesystem is thawed.
|
|
|
|
LOGFILE=/var/log/qga-fsfreeze-hook.log
|
|
FSFREEZE_D=$(dirname -- "$0")/fsfreeze-hook.d
|
|
|
|
# Check whether file $1 is a backup or rpm-generated file and should be ignored
|
|
is_ignored_file() {
|
|
case "$1" in
|
|
*~ | *.bak | *.orig | *.rpmnew | *.rpmorig | *.rpmsave | *.sample | *.dpkg-old | *.dpkg-new | *.dpkg-tmp | *.dpkg-dist | *.dpkg-bak | *.dpkg-backup | *.dpkg-remove)
|
|
return 0 ;;
|
|
esac
|
|
return 1
|
|
}
|
|
|
|
USE_SYSLOG=0
|
|
# if log file is not writable, fallback to syslog
|
|
[ ! -w "$LOGFILE" ] && USE_SYSLOG=1
|
|
# try to update log file and fallback to syslog if it fails
|
|
touch "$LOGFILE" &>/dev/null || USE_SYSLOG=1
|
|
|
|
# Ensure the log file is writable, fallback to syslog if not
|
|
log_message() {
|
|
local message="$1"
|
|
if [ "$USE_SYSLOG" -eq 0 ]; then
|
|
printf "%s: %s\n" "$(date)" "$message" >>"$LOGFILE"
|
|
else
|
|
logger -t qemu-ga-freeze-hook "$message"
|
|
fi
|
|
}
|
|
|
|
# Iterate executables in directory "fsfreeze-hook.d" with the specified args
|
|
[ ! -d "$FSFREEZE_D" ] && exit 0
|
|
|
|
for file in "$FSFREEZE_D"/* ; do
|
|
is_ignored_file "$file" && continue
|
|
[ -x "$file" ] || continue
|
|
|
|
log_message "Executing $file $@"
|
|
if [ "$USE_SYSLOG" -eq 0 ]; then
|
|
"$file" "$@" >>"$LOGFILE" 2>&1
|
|
STATUS=$?
|
|
else
|
|
"$file" "$@" 2>&1 | logger -t qemu-ga-freeze-hook
|
|
STATUS=${PIPESTATUS[0]}
|
|
fi
|
|
|
|
if [ $STATUS -ne 0 ]; then
|
|
log_message "Error: $file finished with status=$STATUS"
|
|
else
|
|
log_message "$file finished successfully"
|
|
fi
|
|
done
|
|
|
|
exit 0
|