mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
vdo: enhance import script for devices file
When the import is used on a system, that uses devices file, the final activation was impossible for the case the converted volume was not present in devices file. Currently add volume automatically in such case. Also add some more debugging output from the script. TODO: Consider enhnacing lvconvert with extending devices file.
This commit is contained in:
parent
b81835b5ca
commit
c693aa8dac
@ -121,8 +121,13 @@ dry() {
|
|||||||
|
|
||||||
cleanup() {
|
cleanup() {
|
||||||
trap '' 2
|
trap '' 2
|
||||||
|
test -n "$VDO_DM_SNAPSHOT_NAME" && {
|
||||||
test -n "$VDO_DM_SNAPSHOT_NAME" && { "$DMSETUP" remove "$VDO_DM_SNAPSHOT_NAME" || true ; }
|
for i in {1..20} ; do
|
||||||
|
test "$("$DMSETUP" info --noheading -co open "$VDO_DM_SNAPSHOT_NAME")" = "0" && break
|
||||||
|
sleep .1
|
||||||
|
done
|
||||||
|
"$DMSETUP" remove "$VDO_DM_SNAPSHOT_NAME" || true
|
||||||
|
}
|
||||||
test -n "$VDO_SNAPSHOT_LOOP" && { "$LOSETUP" -d "$VDO_SNAPSHOT_LOOP" || true ; }
|
test -n "$VDO_SNAPSHOT_LOOP" && { "$LOSETUP" -d "$VDO_SNAPSHOT_LOOP" || true ; }
|
||||||
|
|
||||||
test -z "$PROMPTING" || echo "No"
|
test -z "$PROMPTING" || echo "No"
|
||||||
@ -370,7 +375,13 @@ convert_non_lv_() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
verbose "Moving VDO header."
|
verbose "Moving VDO header."
|
||||||
output=$(dry "$VDO" convert $VDOCONF $VERB --force --name "$VDONAME")
|
|
||||||
|
output=$(dry "$VDO" convert $VDOCONF $VERB --force --name "$VDONAME" 2>&1) || {
|
||||||
|
echo "$output"
|
||||||
|
error "Failed to convert VDO volume \"$DEVICE\" (exit code $?)."
|
||||||
|
}
|
||||||
|
|
||||||
|
echo "$output"
|
||||||
|
|
||||||
if [ "$ABORT_AFTER_VDO_CONVERT" != "0" ] ; then
|
if [ "$ABORT_AFTER_VDO_CONVERT" != "0" ] ; then
|
||||||
verbose "Aborting VDO conversion after moving VDO header, volume is useless!"
|
verbose "Aborting VDO conversion after moving VDO header, volume is useless!"
|
||||||
@ -456,12 +467,19 @@ convert_non_lv_() {
|
|||||||
dry snapshot_merge_ "$DEVICE"
|
dry snapshot_merge_ "$DEVICE"
|
||||||
if [ -e "$TEMPDIR/vdo_snap.yml" ]; then
|
if [ -e "$TEMPDIR/vdo_snap.yml" ]; then
|
||||||
dry cp "$TEMPDIR/vdo_snap.yml" "$VDO_CONFIG"
|
dry cp "$TEMPDIR/vdo_snap.yml" "$VDO_CONFIG"
|
||||||
else
|
elif [ -e "$VDO_CONFIG" ]; then
|
||||||
dry rm -f "$VDO_CONFIG"
|
dry rm -f "$VDO_CONFIG"
|
||||||
fi
|
fi
|
||||||
verbose "Merging of VDO device finished."
|
verbose "Merging of VDO device finished."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
output=$(dry "$LVM" pvs "$DEVICE" 2>&1) || {
|
||||||
|
if echo "$output" | grep -q "not in devices file" ; then
|
||||||
|
verbose "Adding \"$DEVICE\" to devices file."
|
||||||
|
dry "$LVM" lvmdevices --adddev "$DEVICE"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
dry "$LVM" lvchange -ay $VERB $FORCE "$VGNAME/$LVNAME"
|
dry "$LVM" lvchange -ay $VERB $FORCE "$VGNAME/$LVNAME"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user