 85978dfb6b
			
		
	
	
		85978dfb6b
		
	
	
	
	
		
			
			Make sure the error log of fsfreeze hooks when freeze/thaw/snapshot could be logged to system logs if the default logfile of qga can't be written or other situations Signed-off-by: Dehan Meng <demeng@redhat.com> Reviewed-by: Yan Vugenfirer <yvugenfi@redhat.com> Reviewed-by: Konstantin Kostiuk <kkostiuk@redhat.com> Message-ID: <20241225083744.277374-1-demeng@redhat.com> Signed-off-by: Konstantin Kostiuk <kkostiuk@redhat.com>
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/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
 |