1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +03:00

blkdeactivate: add -m|--mpathoption disablequeueing and use it for blk-availability systemd service and initscript

blkdeactivate -m disablequeueing causes "multipathd disablequeueing maps"
call inside blkdeactivate script before deactivating devices. This
avoids a situation where blkdeactivate may wait for paths to appear if
multipath is set to queueing and there's a stack of other devices and/or
mount points on top of such multipath device.

See also https://bugzilla.redhat.com/show_bug.cgi?id=1344381.
This commit is contained in:
Peter Rajnoha 2016-07-12 09:52:18 +02:00
parent 9f7e8f22dc
commit 42e76a1920
5 changed files with 64 additions and 12 deletions

View File

@ -1,5 +1,7 @@
Version 1.02.131 - Version 1.02.131 -
================================ ================================
Disable queueing on mpath devs in blk-availability systemd service/initscript.
Add new -m|--mpathoption disablequeueing to blkdeactivate.
Automatically group regions with 'create --segments' unless --nogroup. Automatically group regions with 'create --segments' unless --nogroup.
Fix resource leak when deleting the first member of a group. Fix resource leak when deleting the first member of a group.
Allow --bounds with 'create --filemap' for dmstats. Allow --bounds with 'create --filemap' for dmstats.

View File

@ -7,6 +7,7 @@ blkdeactivate \(em utility to deactivate block devices
.RB [ \-e ] .RB [ \-e ]
.RB [ \-h ] .RB [ \-h ]
.RB [ \-l \ \fIlvm_options\fP ] .RB [ \-l \ \fIlvm_options\fP ]
.RB [ \-m \ \fImpath_options\fP ]
.RB [ \-u ] .RB [ \-u ]
.RB [ \-v ] .RB [ \-v ]
.RI [ device ] .RI [ device ]
@ -51,6 +52,16 @@ Deactivating Volume Group as a whole takes less time than deactivating each
Logical Volume separately. Logical Volume separately.
.RE .RE
.TP .TP
.BR \-m ", " \-\-mpathoption \ \fImpath_options\fP
Comma separated list of device-mapper multipath specific options:
.RS
.IP \fIdisablequeueing\fP
Disable queueing on all multipath devices first before deactivation.
This avoids a situation where blkdeactivate may end up waiting if
all paths are unavailable for any underlying device-mapper multipath
device.
.RE
.TP
.BR \-u ", " \-\-umount .BR \-u ", " \-\-umount
Unmount a mounted device before trying to deactivate it. Unmount a mounted device before trying to deactivate it.
Without this option used, a device that is mounted is not deactivated. Without this option used, a device that is mounted is not deactivated.
@ -90,4 +101,5 @@ of device-mapper devices in case the deactivation fails and force removal.
.BR lsblk (8), .BR lsblk (8),
.BR lvm (8), .BR lvm (8),
.BR mdadm (8), .BR mdadm (8),
.BR multipathd (8),
.BR umount (8) .BR umount (8)

View File

@ -33,7 +33,7 @@
sbindir=@sbindir@ sbindir=@sbindir@
script=blkdeactivate script=blkdeactivate
options="-u -l wholevg" options="-u -l wholevg -m disablequeueing"
LOCK_FILE="/var/lock/subsys/blk-availability" LOCK_FILE="/var/lock/subsys/blk-availability"

View File

@ -7,7 +7,7 @@ Conflicts=shutdown.target
[Service] [Service]
Type=oneshot Type=oneshot
ExecStart=/usr/bin/true ExecStart=/usr/bin/true
ExecStop=@sbindir@/blkdeactivate -u -l wholevg ExecStop=@sbindir@/blkdeactivate -u -l wholevg -m disablequeueing
RemainAfterExit=yes RemainAfterExit=yes
[Install] [Install]

View File

@ -38,6 +38,7 @@ UMOUNT="/bin/umount"
DMSETUP="@sbindir@/dmsetup" DMSETUP="@sbindir@/dmsetup"
LVM="@sbindir@/lvm" LVM="@sbindir@/lvm"
MDADM="@sbindir@/mdadm" MDADM="@sbindir@/mdadm"
MPATHD="/sbin/multipathd"
if $UMOUNT --help | grep -- "--all-targets" >$DEV_DIR/null; then if $UMOUNT --help | grep -- "--all-targets" >$DEV_DIR/null; then
UMOUNT_OPTS="--all-targets " UMOUNT_OPTS="--all-targets "
@ -49,6 +50,7 @@ fi
DMSETUP_OPTS="" DMSETUP_OPTS=""
LVM_OPTS="" LVM_OPTS=""
MDADM_OPTS="" MDADM_OPTS=""
MPATHD_OPTS=""
LSBLK="/bin/lsblk -r --noheadings -o TYPE,KNAME,NAME,MOUNTPOINT" LSBLK="/bin/lsblk -r --noheadings -o TYPE,KNAME,NAME,MOUNTPOINT"
LSBLK_VARS="local devtype local kname local name local mnt" LSBLK_VARS="local devtype local kname local name local mnt"
@ -68,6 +70,9 @@ LVM_DO_WHOLE_VG=0
# Do not retry LV deactivation by default. # Do not retry LV deactivation by default.
LVM_CONFIG="activation{retry_deactivation=0}" LVM_CONFIG="activation{retry_deactivation=0}"
# Do not disable queueing if set on multipath devices.
MPATHD_DO_DISABLEQUEUEING=0
# #
# List of device names and/or VGs to be skipped. # List of device names and/or VGs to be skipped.
# Device name is the KNAME from lsblk output. # Device name is the KNAME from lsblk output.
@ -111,6 +116,7 @@ usage() {
echo " -h | --help Show this help message" echo " -h | --help Show this help message"
echo " -d | --dmoption DM_OPTIONS Comma separated DM specific options" echo " -d | --dmoption DM_OPTIONS Comma separated DM specific options"
echo " -l | --lvmoption LVM_OPTIONS Comma separated LVM specific options" echo " -l | --lvmoption LVM_OPTIONS Comma separated LVM specific options"
echo " -m | --mpathoption MPATH_OPTIONS Comma separated DM-multipath specific options"
echo " -u | --umount Unmount the device if mounted" echo " -u | --umount Unmount the device if mounted"
echo " -v | --verbose Verbose mode (also implies -e)" echo " -v | --verbose Verbose mode (also implies -e)"
echo echo
@ -121,6 +127,8 @@ usage() {
echo " LVM_OPTIONS:" echo " LVM_OPTIONS:"
echo " retry retry removal several times in case of failure" echo " retry retry removal several times in case of failure"
echo " wholevg deactivate the whole VG when processing an LV" echo " wholevg deactivate the whole VG when processing an LV"
echo " MPATH_OPTIONS:"
echo " disablequeueing disable queueing on all DM-multipath devices first"
exit exit
} }
@ -312,6 +320,11 @@ deactivate_all() {
echo "Deactivating block devices:" echo "Deactivating block devices:"
test $MPATHD_RUNNING -eq 1 && {
echo -n " [DM]: disabling queueing on all multipath devices... "
eval $MPATHD $MPATHD_OPTS disablequeueing maps $ERR | grep '^ok$' >$DEV_DIR/null && echo "done" || echo "failed"
}
if test $# -eq 0; then if test $# -eq 0; then
####################### #######################
# Process all devices # # Process all devices #
@ -406,6 +419,20 @@ get_lvmopts() {
IFS=$ORIG_IFS IFS=$ORIG_IFS
} }
get_mpathopts() {
ORIG_IFS=$IFS; IFS=','
for opt in $1; do
case "$opt" in
"") ;;
"disablequeueing") MPATHD_DO_DISABLEQUEUEING=1 ;;
*) echo "$opt: unknown DM-multipath option"
esac
done
IFS=$ORIG_IFS
}
set_env() { set_env() {
if test "$ERRORS" -eq "1"; then if test "$ERRORS" -eq "1"; then
unset ERR unset ERR
@ -419,6 +446,7 @@ set_env() {
DMSETUP_OPTS+="-vvvv" DMSETUP_OPTS+="-vvvv"
LVM_OPTS+="-vvvv" LVM_OPTS+="-vvvv"
MDADM_OPTS+="-vv" MDADM_OPTS+="-vv"
MPATHD_OPTS+="-v 3"
else else
OUT="1>$DEV_DIR/null" OUT="1>$DEV_DIR/null"
fi fi
@ -434,6 +462,15 @@ set_env() {
else else
MDADM_AVAILABLE=0 MDADM_AVAILABLE=0
fi fi
MPATHD_RUNNING=0
test $MPATHD_DO_DISABLEQUEUEING -eq 1 && {
if test -f $MPATHD; then
if eval $MPATHD show daemon $ERR | grep "running" >$DEVDIR/null; then
MPATHD_RUNNING=1
fi
fi
}
} }
while test $# -ne 0; do while test $# -ne 0; do
@ -443,6 +480,7 @@ while test $# -ne 0; do
"-h"|"--help") usage ;; "-h"|"--help") usage ;;
"-d"|"--dmoption ") get_dmopts "$2" ; shift ;; "-d"|"--dmoption ") get_dmopts "$2" ; shift ;;
"-l"|"--lvmoption ") get_lvmopts "$2" ; shift ;; "-l"|"--lvmoption ") get_lvmopts "$2" ; shift ;;
"-m"|"--mpathoption ") get_mpathopts "$2" ; shift ;;
"-u"|"--umount") DO_UMOUNT=1 ;; "-u"|"--umount") DO_UMOUNT=1 ;;
"-v"|"--verbose") VERBOSE=1 ; ERRORS=1 ;; "-v"|"--verbose") VERBOSE=1 ; ERRORS=1 ;;
"-vv") VERBOSE=1 ; ERRORS=1 ; set -x ;; "-vv") VERBOSE=1 ; ERRORS=1 ; set -x ;;