1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-22 22:03:39 +03:00

feature #1727: add clone resize to ssh, shared and qcow2

This commit is contained in:
Javi Fontan 2015-07-20 17:10:21 -04:00
parent eca7640da1
commit 66b83c0f75
3 changed files with 100 additions and 2 deletions

View File

@ -38,6 +38,8 @@ fi
. $TMCOMMON . $TMCOMMON
DRIVER_PATH=$(dirname $0)
#------------------------------------------------------------------------------- #-------------------------------------------------------------------------------
# Set dst path and dir # Set dst path and dir
#------------------------------------------------------------------------------- #-------------------------------------------------------------------------------
@ -52,6 +54,26 @@ SRC_DS_PATH="$(dirname $(dirname $SRC_ARG_PATH))"
SRC_PATH="${DST_DS_PATH}${SRC_ARG_PATH##$SRC_DS_PATH}" SRC_PATH="${DST_DS_PATH}${SRC_ARG_PATH##$SRC_DS_PATH}"
#-------------------------------------------------------------------------------
# Get Image information
#-------------------------------------------------------------------------------
DISK_ID=$(basename ${DST_PATH} | cut -d. -f2)
XPATH="${DRIVER_PATH}/../../datastore/xpath.rb --stdin"
unset i j XPATH_ELEMENTS
while IFS= read -r -d '' element; do
XPATH_ELEMENTS[i++]="$element"
done < <(onevm show -x $VMID| $XPATH \
/VM/TEMPLATE/DISK[DISK_ID=$DISK_ID]/SIZE \
/VM/TEMPLATE/DISK[DISK_ID=$DISK_ID]/ORIGINAL_SIZE)
SIZE="${XPATH_ELEMENTS[j++]}"
ORIGINAL_SIZE="${XPATH_ELEMENTS[j++]}"
ssh_make_path $DST_HOST $DST_DIR ssh_make_path $DST_HOST $DST_DIR
#------------------------------------------------------------------------------- #-------------------------------------------------------------------------------
@ -68,7 +90,17 @@ http://*)
*) *)
log "Cloning $SRC_PATH in $DST" log "Cloning $SRC_PATH in $DST"
CLONE_CMD="cd $DST_DIR; rm -f $DST_PATH; $QEMU_IMG create -b $SRC_PATH -f qcow2 $DST_PATH" if [ -n $ORIGINAL_SIZE ]; then
ORIGINAL_SIZE="0"
fi
if [ "$SIZE" -ge "$ORIGINAL_SIZE" ]; then
RESIZE_CMD="; qemu-img resize ${DST_PATH} ${SIZE}M"
fi
CLONE_CMD="cd $DST_DIR; \
rm -f $DST_PATH; $QEMU_IMG create -b $SRC_PATH -f qcow2 $DST_PATH \
${RESIZE_CMD}"
ssh_exec_and_log "$DST_HOST" "$CLONE_CMD" "Error copying $SRC to $DST" ssh_exec_and_log "$DST_HOST" "$CLONE_CMD" "Error copying $SRC to $DST"
;; ;;
esac esac

View File

@ -38,6 +38,8 @@ fi
. $TMCOMMON . $TMCOMMON
DRIVER_PATH=$(dirname $0)
#------------------------------------------------------------------------------- #-------------------------------------------------------------------------------
# Set dst path and dir # Set dst path and dir
#------------------------------------------------------------------------------- #-------------------------------------------------------------------------------
@ -52,6 +54,26 @@ SRC_DS_PATH="$(dirname $(dirname $SRC_ARG_PATH))"
SRC_PATH="${DST_DS_PATH}${SRC_ARG_PATH##$SRC_DS_PATH}" SRC_PATH="${DST_DS_PATH}${SRC_ARG_PATH##$SRC_DS_PATH}"
#-------------------------------------------------------------------------------
# Get Image information
#-------------------------------------------------------------------------------
DISK_ID=$(basename ${DST_PATH} | cut -d. -f2)
XPATH="${DRIVER_PATH}/../../datastore/xpath.rb --stdin"
unset i j XPATH_ELEMENTS
while IFS= read -r -d '' element; do
XPATH_ELEMENTS[i++]="$element"
done < <(onevm show -x $VMID| $XPATH \
/VM/TEMPLATE/DISK[DISK_ID=$DISK_ID]/SIZE \
/VM/TEMPLATE/DISK[DISK_ID=$DISK_ID]/ORIGINAL_SIZE)
SIZE="${XPATH_ELEMENTS[j++]}"
ORIGINAL_SIZE="${XPATH_ELEMENTS[j++]}"
#------------------------------------------------------------------------------- #-------------------------------------------------------------------------------
# Create DST path # Create DST path
#------------------------------------------------------------------------------- #-------------------------------------------------------------------------------
@ -72,8 +94,21 @@ http://*)
*) *)
log "Cloning $SRC_PATH in $DST" log "Cloning $SRC_PATH in $DST"
if [ -n $ORIGINAL_SIZE ]; then
ORIGINAL_SIZE="0"
fi
if [ "$SIZE" -ge "$ORIGINAL_SIZE" ]; then
RESIZE_CMD="; qemu-img resize ${DST_PATH} ${SIZE}M"
fi
CLONE_CMD="cd ${DST_DIR}; \
cp ${SRC_PATH} ${DST_PATH} \
${RESIZE_CMD}"
ssh_exec_and_log $DST_HOST \ ssh_exec_and_log $DST_HOST \
"cd $DST_DIR; cp $SRC_PATH $DST_PATH" \ "$CLONE_CMD" \
"Error copying $SRC to $DST" "Error copying $SRC to $DST"
;; ;;
esac esac

View File

@ -38,6 +38,8 @@ fi
. $TMCOMMON . $TMCOMMON
DRIVER_PATH=$(dirname $0)
#------------------------------------------------------------------------------- #-------------------------------------------------------------------------------
# Set dst path and dir # Set dst path and dir
#------------------------------------------------------------------------------- #-------------------------------------------------------------------------------
@ -53,6 +55,25 @@ DST_DIR=`dirname $DST_PATH`
ssh_make_path $DST_HOST $DST_DIR ssh_make_path $DST_HOST $DST_DIR
#-------------------------------------------------------------------------------
# Get Image information
#-------------------------------------------------------------------------------
DISK_ID=$(basename ${DST_PATH} | cut -d. -f2)
XPATH="${DRIVER_PATH}/../../datastore/xpath.rb --stdin"
unset i j XPATH_ELEMENTS
while IFS= read -r -d '' element; do
XPATH_ELEMENTS[i++]="$element"
done < <(onevm show -x $VMID| $XPATH \
/VM/TEMPLATE/DISK[DISK_ID=$DISK_ID]/SIZE \
/VM/TEMPLATE/DISK[DISK_ID=$DISK_ID]/ORIGINAL_SIZE)
SIZE="${XPATH_ELEMENTS[j++]}"
ORIGINAL_SIZE="${XPATH_ELEMENTS[j++]}"
#------------------------------------------------------------------------------- #-------------------------------------------------------------------------------
# Copy files to the remote host # Copy files to the remote host
#------------------------------------------------------------------------------- #-------------------------------------------------------------------------------
@ -71,6 +92,16 @@ http://*)
exec_and_log "$SCP -r ${SRC_PATH_SNAP} ${DST_PATH_SNAP}" \ exec_and_log "$SCP -r ${SRC_PATH_SNAP} ${DST_PATH_SNAP}" \
"Error copying $SRC to $DST" "Error copying $SRC to $DST"
fi fi
if [ -n $ORIGINAL_SIZE ]; then
ORIGINAL_SIZE="0"
fi
if [ "$SIZE" -ge "$ORIGINAL_SIZE" ]; then
RESIZE_CMD="qemu-img resize ${DST_PATH} ${SIZE}M"
ssh_exec_and_log "$DST_HOST" "$RESIZE_CMD" \
"Error resizing image $DST"
fi
;; ;;
esac esac