提交 08071ec0 编写于 作者: P Prathamesh Chavan 提交者: Michal Privoznik

tools: variables clean-up in libvirt-guests script

Redeclared variables in script functions marked as local.
Variables `guest_running` and `guests_shutting_down` in the
functions 'guest_is_on` and `check_guests_shutdown` were
untouched, as the functions returned values in these
variables.
Signed-off-by: NPrathamesh Chavan <pc44800@gmail.com>
Reviewed-by: NMichal Privoznik <mprivozn@redhat.com>
上级 333fd2bd
...@@ -65,7 +65,7 @@ retval() { ...@@ -65,7 +65,7 @@ retval() {
# If URI is "default" virsh is called without the "-c" argument # If URI is "default" virsh is called without the "-c" argument
# (using libvirt's default connection) # (using libvirt's default connection)
run_virsh() { run_virsh() {
uri=$1 local uri=$1
shift shift
if [ "x$uri" = xdefault ]; then if [ "x$uri" = xdefault ]; then
...@@ -86,7 +86,7 @@ run_virsh_c() { ...@@ -86,7 +86,7 @@ run_virsh_c() {
# check if URI is reachable # check if URI is reachable
test_connect() test_connect()
{ {
uri=$1 local uri=$1
if run_virsh "$uri" connect 2>/dev/null; then if run_virsh "$uri" connect 2>/dev/null; then
return 0; return 0;
...@@ -103,10 +103,10 @@ test_connect() ...@@ -103,10 +103,10 @@ test_connect()
# --transient: list only transient guests # --transient: list only transient guests
# [none]: list both persistent and transient guests # [none]: list both persistent and transient guests
list_guests() { list_guests() {
uri=$1 local uri=$1
persistent=$2 local persistent=$2
local list=$(run_virsh_c "$uri" list --uuid $persistent)
list=$(run_virsh_c "$uri" list --uuid $persistent)
if [ $? -ne 0 ]; then if [ $? -ne 0 ]; then
RETVAL=1 RETVAL=1
return 1 return 1
...@@ -118,8 +118,8 @@ list_guests() { ...@@ -118,8 +118,8 @@ list_guests() {
# guest_name URI UUID # guest_name URI UUID
# return name of guest UUID on URI # return name of guest UUID on URI
guest_name() { guest_name() {
uri=$1 local uri=$1
uuid=$2 local uuid=$2
run_virsh "$uri" domname "$uuid" 2>/dev/null run_virsh "$uri" domname "$uuid" 2>/dev/null
} }
...@@ -128,11 +128,11 @@ guest_name() { ...@@ -128,11 +128,11 @@ guest_name() {
# check if guest UUID on URI is running # check if guest UUID on URI is running
# Result is returned by variable "guest_running" # Result is returned by variable "guest_running"
guest_is_on() { guest_is_on() {
uri=$1 local uri=$1
uuid=$2 local uuid=$2
local id=$(run_virsh "$uri" domid "$uuid")
guest_running=false guest_running=false
id=$(run_virsh "$uri" domid "$uuid")
if [ $? -ne 0 ]; then if [ $? -ne 0 ]; then
RETVAL=1 RETVAL=1
return 1 return 1
...@@ -151,6 +151,12 @@ started() { ...@@ -151,6 +151,12 @@ started() {
# start # start
# Start or resume the guests # Start or resume the guests
start() { start() {
local isfirst=true
local bypass=
local sync_time=false
local uri=
local list=
[ -f "$LISTFILE" ] || { started; return 0; } [ -f "$LISTFILE" ] || { started; return 0; }
if [ "x$ON_BOOT" != xstart ]; then if [ "x$ON_BOOT" != xstart ]; then
...@@ -161,13 +167,13 @@ start() { ...@@ -161,13 +167,13 @@ start() {
return 0 return 0
fi fi
isfirst=true
bypass=
sync_time=false
test "x$BYPASS_CACHE" = x0 || bypass=--bypass-cache test "x$BYPASS_CACHE" = x0 || bypass=--bypass-cache
test "x$SYNC_TIME" = x0 || sync_time=true test "x$SYNC_TIME" = x0 || sync_time=true
while read uri list; do while read uri list; do
configured=false local configured=false
local confuri=
local guest=
set -f set -f
for confuri in $URIS; do for confuri in $URIS; do
set +f set +f
...@@ -186,7 +192,7 @@ start() { ...@@ -186,7 +192,7 @@ start() {
eval_gettext "Resuming guests on \$uri URI..."; echo eval_gettext "Resuming guests on \$uri URI..."; echo
for guest in $list; do for guest in $list; do
name=$(guest_name "$uri" "$guest") local name=$(guest_name "$uri" "$guest")
eval_gettext "Resuming guest \$name: " eval_gettext "Resuming guest \$name: "
if guest_is_on "$uri" "$guest"; then if guest_is_on "$uri" "$guest"; then
if "$guest_running"; then if "$guest_running"; then
...@@ -217,24 +223,24 @@ start() { ...@@ -217,24 +223,24 @@ start() {
# was saved. # was saved.
suspend_guest() suspend_guest()
{ {
uri=$1 local uri=$1
guest=$2 local guest=$2
local name=$(guest_name "$uri" "$guest")
local label=$(eval_gettext "Suspending \$name: ")
local bypass=
local slept=0
name=$(guest_name "$uri" "$guest")
label=$(eval_gettext "Suspending \$name: ")
bypass=
slept=0
test "x$BYPASS_CACHE" = x0 || bypass=--bypass-cache test "x$BYPASS_CACHE" = x0 || bypass=--bypass-cache
printf '%s...\n' "$label" printf '%s...\n' "$label"
run_virsh "$uri" managedsave $bypass "$guest" >/dev/null & run_virsh "$uri" managedsave $bypass "$guest" >/dev/null &
virsh_pid=$! local virsh_pid=$!
while true; do while true; do
sleep 1 sleep 1
kill -0 "$virsh_pid" >/dev/null 2>&1 || break kill -0 "$virsh_pid" >/dev/null 2>&1 || break
slept=$(($slept + 1)) slept=$(($slept + 1))
if [ $(($slept % 5)) -eq 0 ]; then if [ $(($slept % 5)) -eq 0 ]; then
progress=$(run_virsh_c "$uri" domjobinfo "$guest" 2>/dev/null | \ local progress=$(run_virsh_c "$uri" domjobinfo "$guest" 2>/dev/null | \
awk '/^Data processed:/{print $3, $4}') awk '/^Data processed:/{print $3, $4}')
if [ -n "$progress" ]; then if [ -n "$progress" ]; then
printf '%s%s\n' "$label" "$progress" printf '%s%s\n' "$label" "$progress"
...@@ -251,15 +257,18 @@ suspend_guest() ...@@ -251,15 +257,18 @@ suspend_guest()
# was successfully shutdown or the timeout defined by $SHUTDOWN_TIMEOUT expired. # was successfully shutdown or the timeout defined by $SHUTDOWN_TIMEOUT expired.
shutdown_guest() shutdown_guest()
{ {
uri=$1 local uri=$1
guest=$2 local guest=$2
local name=$(guest_name "$uri" "$guest")
local timeout=$SHUTDOWN_TIMEOUT
local check_timeout=false
local format=
local slept=
name=$(guest_name "$uri" "$guest")
eval_gettext "Starting shutdown on guest: \$name" eval_gettext "Starting shutdown on guest: \$name"
echo echo
retval run_virsh "$uri" shutdown "$guest" >/dev/null || return retval run_virsh "$uri" shutdown "$guest" >/dev/null || return
timeout=$SHUTDOWN_TIMEOUT
check_timeout=false
if [ $timeout -gt 0 ]; then if [ $timeout -gt 0 ]; then
check_timeout=true check_timeout=true
format=$(eval_gettext "Waiting for guest %s to shut down, %d seconds left\n") format=$(eval_gettext "Waiting for guest %s to shut down, %d seconds left\n")
...@@ -300,10 +309,10 @@ shutdown_guest() ...@@ -300,10 +309,10 @@ shutdown_guest()
# was issued to libvirt to allow parallel shutdown. # was issued to libvirt to allow parallel shutdown.
shutdown_guest_async() shutdown_guest_async()
{ {
uri=$1 local uri=$1
guest=$2 local guest=$2
local name=$(guest_name "$uri" "$guest")
name=$(guest_name "$uri" "$guest")
eval_gettext "Starting shutdown on guest: \$name" eval_gettext "Starting shutdown on guest: \$name"
echo echo
retval run_virsh "$uri" shutdown "$guest" > /dev/null retval run_virsh "$uri" shutdown "$guest" > /dev/null
...@@ -323,8 +332,9 @@ guest_count() ...@@ -323,8 +332,9 @@ guest_count()
# Result is returned in "guests_shutting_down" # Result is returned in "guests_shutting_down"
check_guests_shutdown() check_guests_shutdown()
{ {
uri=$1 local uri=$1
guests_to_check=$2 local guests_to_check=$2
local guest=
guests_shutting_down= guests_shutting_down=
for guest in $guests_to_check; do for guest in $guests_to_check; do
...@@ -344,16 +354,17 @@ check_guests_shutdown() ...@@ -344,16 +354,17 @@ check_guests_shutdown()
# a shutdown complete notice for guests that have finished # a shutdown complete notice for guests that have finished
print_guests_shutdown() print_guests_shutdown()
{ {
uri=$1 local uri=$1
before=$2 local before=$2
after=$3 local after=$3
local guest=
for guest in $before; do for guest in $before; do
case " $after " in case " $after " in
*" $guest "*) continue;; *" $guest "*) continue;;
esac esac
name=$(guest_name "$uri" "$guest") local name=$(guest_name "$uri" "$guest")
if [ -n "$name" ]; then if [ -n "$name" ]; then
eval_gettext "Shutdown of guest \$name complete." eval_gettext "Shutdown of guest \$name complete."
echo echo
...@@ -365,12 +376,14 @@ print_guests_shutdown() ...@@ -365,12 +376,14 @@ print_guests_shutdown()
# Shutdown guests GUESTS on machine URI in parallel # Shutdown guests GUESTS on machine URI in parallel
shutdown_guests_parallel() shutdown_guests_parallel()
{ {
uri=$1 local uri=$1
guests=$2 local guests=$2
local on_shutdown=
local check_timeout=false
local timeout=$SHUTDOWN_TIMEOUT
local slept=
local format=
on_shutdown=
check_timeout=false
timeout=$SHUTDOWN_TIMEOUT
if [ $timeout -gt 0 ]; then if [ $timeout -gt 0 ]; then
check_timeout=true check_timeout=true
format=$(eval_gettext "Waiting for %d guests to shut down, %d seconds left\n") format=$(eval_gettext "Waiting for %d guests to shut down, %d seconds left\n")
...@@ -382,7 +395,7 @@ shutdown_guests_parallel() ...@@ -382,7 +395,7 @@ shutdown_guests_parallel()
while [ -n "$guests" ] && while [ -n "$guests" ] &&
[ $(guest_count "$on_shutdown") -lt "$PARALLEL_SHUTDOWN" ]; do [ $(guest_count "$on_shutdown") -lt "$PARALLEL_SHUTDOWN" ]; do
set -- $guests set -- $guests
guest=$1 local guest=$1
shift shift
guests=$* guests=$*
if [ -z "$(echo $on_shutdown | grep $guest)" ] && if [ -z "$(echo $on_shutdown | grep $guest)" ] &&
...@@ -394,9 +407,9 @@ shutdown_guests_parallel() ...@@ -394,9 +407,9 @@ shutdown_guests_parallel()
sleep 1 sleep 1
set -- $guests set -- $guests
guestcount=$# local guestcount=$#
set -- $on_shutdown set -- $on_shutdown
shutdowncount=$# local shutdowncount=$#
if $check_timeout; then if $check_timeout; then
if [ $(($timeout % 5)) -eq 0 ]; then if [ $(($timeout % 5)) -eq 0 ]; then
...@@ -415,7 +428,7 @@ shutdown_guests_parallel() ...@@ -415,7 +428,7 @@ shutdown_guests_parallel()
fi fi
fi fi
on_shutdown_prev=$on_shutdown local on_shutdown_prev=$on_shutdown
check_guests_shutdown "$uri" "$on_shutdown" check_guests_shutdown "$uri" "$on_shutdown"
on_shutdown="$guests_shutting_down" on_shutdown="$guests_shutting_down"
print_guests_shutdown "$uri" "$on_shutdown_prev" "$on_shutdown" print_guests_shutdown "$uri" "$on_shutdown_prev" "$on_shutdown"
...@@ -425,11 +438,13 @@ shutdown_guests_parallel() ...@@ -425,11 +438,13 @@ shutdown_guests_parallel()
# stop # stop
# Shutdown or save guests on the configured uris # Shutdown or save guests on the configured uris
stop() { stop() {
local suspending=true
local uri=
# last stop was not followed by start # last stop was not followed by start
[ -f "$LISTFILE" ] && return 0 [ -f "$LISTFILE" ] && return 0
suspending=true if [ "/x$ON_SHUTDOWN" = xshutdown ]; then
if [ "x$ON_SHUTDOWN" = xshutdown ]; then
suspending=false suspending=false
if [ $SHUTDOWN_TIMEOUT -lt 0 ]; then if [ $SHUTDOWN_TIMEOUT -lt 0 ]; then
gettext "SHUTDOWN_TIMEOUT must be equal or greater than 0" gettext "SHUTDOWN_TIMEOUT must be equal or greater than 0"
...@@ -448,9 +463,9 @@ stop() { ...@@ -448,9 +463,9 @@ stop() {
eval_gettext "Running guests on \$uri URI: " eval_gettext "Running guests on \$uri URI: "
list=$(list_guests "$uri") local list=$(list_guests "$uri")
if [ $? -eq 0 ]; then if [ $? -eq 0 ]; then
empty=true local empty=true
for uuid in $list; do for uuid in $list; do
"$empty" || printf ", " "$empty" || printf ", "
printf %s "$(guest_name "$uri" "$uuid")" printf %s "$(guest_name "$uri" "$uuid")"
...@@ -464,9 +479,11 @@ stop() { ...@@ -464,9 +479,11 @@ stop() {
fi fi
if "$suspending"; then if "$suspending"; then
transient=$(list_guests "$uri" "--transient") local transient=$(list_guests "$uri" "--transient")
if [ $? -eq 0 ]; then if [ $? -eq 0 ]; then
empty=true local empty=true
local uuid=
for uuid in $transient; do for uuid in $transient; do
if "$empty"; then if "$empty"; then
eval_gettext "Not suspending transient guests on URI: \$uri: " eval_gettext "Not suspending transient guests on URI: \$uri: "
...@@ -513,6 +530,7 @@ stop() { ...@@ -513,6 +530,7 @@ stop() {
! "$suspending"; then ! "$suspending"; then
shutdown_guests_parallel "$uri" "$list" shutdown_guests_parallel "$uri" "$list"
else else
local guest=
for guest in $list; do for guest in $list; do
if "$suspending"; then if "$suspending"; then
suspend_guest "$uri" "$guest" suspend_guest "$uri" "$guest"
...@@ -532,6 +550,7 @@ stop() { ...@@ -532,6 +550,7 @@ stop() {
# gueststatus # gueststatus
# List status of guests # List status of guests
gueststatus() { gueststatus() {
local uri=
set -f set -f
for uri in $URIS; do for uri in $URIS; do
set +f set +f
...@@ -563,7 +582,7 @@ rh_status() { ...@@ -563,7 +582,7 @@ rh_status() {
# usage [val] # usage [val]
# Display usage string, then exit with VAL (defaults to 2). # Display usage string, then exit with VAL (defaults to 2).
usage() { usage() {
program_name=$0 local program_name=$0
eval_gettext "Usage: \$program_name {start|stop|status|restart|"\ eval_gettext "Usage: \$program_name {start|stop|status|restart|"\
"condrestart|try-restart|reload|force-reload|gueststatus|shutdown}"; echo "condrestart|try-restart|reload|force-reload|gueststatus|shutdown}"; echo
exit ${1-2} exit ${1-2}
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册