Properly use the Dracut cleanup hook to order pool shutdown
When Dracut starts up, it needs to determine whether a pool will remain "hanging open" before the system shuts off. In such a case, then the code to clean up the pool (using the previous export -F work) must be invoked. Since Dracut has had a recent change that makes mount-zfs.sh simply not run when the root dataset is already mounted, we must use the cleanup hook to order Dracut to do shutdown cleanup. Important note: this code will not accomplish its stated goal until this bug is fixed: https://bugzilla.redhat.com/show_bug.cgi?id=1385432 That bug impacts more than just ZFS. It impacts LUKS, dmraid, and unmount during poweroff. It is a Fedora-wide bug. Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Manuel Amador (Rudd-O) <rudd-o@rudd-o.com> Closes #5287
This commit is contained in:
parent
fea33e4e50
commit
f8e87e205c
@ -5,6 +5,7 @@ pkgdracut_SCRIPTS = \
|
|||||||
mount-zfs.sh \
|
mount-zfs.sh \
|
||||||
parse-zfs.sh \
|
parse-zfs.sh \
|
||||||
zfs-generator.sh \
|
zfs-generator.sh \
|
||||||
|
zfs-needshutdown.sh \
|
||||||
zfs-lib.sh
|
zfs-lib.sh
|
||||||
|
|
||||||
EXTRA_DIST = \
|
EXTRA_DIST = \
|
||||||
@ -13,6 +14,7 @@ EXTRA_DIST = \
|
|||||||
$(top_srcdir)/contrib/dracut/90zfs/mount-zfs.sh.in \
|
$(top_srcdir)/contrib/dracut/90zfs/mount-zfs.sh.in \
|
||||||
$(top_srcdir)/contrib/dracut/90zfs/parse-zfs.sh.in \
|
$(top_srcdir)/contrib/dracut/90zfs/parse-zfs.sh.in \
|
||||||
$(top_srcdir)/contrib/dracut/90zfs/zfs-generator.sh.in \
|
$(top_srcdir)/contrib/dracut/90zfs/zfs-generator.sh.in \
|
||||||
|
$(top_srcdir)/contrib/dracut/90zfs/zfs-needshutdown.sh.in \
|
||||||
$(top_srcdir)/contrib/dracut/90zfs/zfs-lib.sh.in
|
$(top_srcdir)/contrib/dracut/90zfs/zfs-lib.sh.in
|
||||||
|
|
||||||
$(pkgdracut_SCRIPTS):%:%.in
|
$(pkgdracut_SCRIPTS):%:%.in
|
||||||
|
@ -58,6 +58,7 @@ install() {
|
|||||||
inst_script "${moddir}/zfs-generator.sh" "$systemdutildir"/system-generators/dracut-zfs-generator
|
inst_script "${moddir}/zfs-generator.sh" "$systemdutildir"/system-generators/dracut-zfs-generator
|
||||||
fi
|
fi
|
||||||
inst_hook mount 98 "${moddir}/mount-zfs.sh"
|
inst_hook mount 98 "${moddir}/mount-zfs.sh"
|
||||||
|
inst_hook cleanup 99 "${moddir}/zfs-needshutdown.sh"
|
||||||
inst_hook shutdown 20 "${moddir}/export-zfs.sh"
|
inst_hook shutdown 20 "${moddir}/export-zfs.sh"
|
||||||
|
|
||||||
inst_simple "${moddir}/zfs-lib.sh" "/lib/dracut-zfs-lib.sh"
|
inst_simple "${moddir}/zfs-lib.sh" "/lib/dracut-zfs-lib.sh"
|
||||||
|
@ -22,7 +22,6 @@ if [ -e "$GENERATOR_FILE" -a -e "$GENERATOR_EXTENSION" ] ; then
|
|||||||
# Let us tell the initrd to run on shutdown.
|
# Let us tell the initrd to run on shutdown.
|
||||||
# We have a shutdown hook to run
|
# We have a shutdown hook to run
|
||||||
# because we imported the pool.
|
# because we imported the pool.
|
||||||
need_shutdown
|
|
||||||
# We now prevent Dracut from running this thing again.
|
# We now prevent Dracut from running this thing again.
|
||||||
for zfsmounthook in "$hookdir"/mount/*zfs* ; do
|
for zfsmounthook in "$hookdir"/mount/*zfs* ; do
|
||||||
if [ -f "$zfsmounthook" ] ; then
|
if [ -f "$zfsmounthook" ] ; then
|
||||||
@ -60,7 +59,6 @@ if import_pool "${ZFS_POOL}" ; then
|
|||||||
# Let us tell the initrd to run on shutdown.
|
# Let us tell the initrd to run on shutdown.
|
||||||
# We have a shutdown hook to run
|
# We have a shutdown hook to run
|
||||||
# because we imported the pool.
|
# because we imported the pool.
|
||||||
need_shutdown
|
|
||||||
info "ZFS: Mounting dataset ${ZFS_DATASET}..."
|
info "ZFS: Mounting dataset ${ZFS_DATASET}..."
|
||||||
if mount_dataset "${ZFS_DATASET}" ; then
|
if mount_dataset "${ZFS_DATASET}" ; then
|
||||||
ROOTFS_MOUNTED=yes
|
ROOTFS_MOUNTED=yes
|
||||||
|
10
contrib/dracut/90zfs/zfs-needshutdown.sh.in
Normal file
10
contrib/dracut/90zfs/zfs-needshutdown.sh.in
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
type getarg >/dev/null 2>&1 || . /lib/dracut-lib.sh
|
||||||
|
|
||||||
|
if zpool list 2>&1 | grep -q 'no pools available' ; then
|
||||||
|
info "ZFS: No active pools, no need to export anything."
|
||||||
|
else
|
||||||
|
info "ZFS: There is an active pool, will export it."
|
||||||
|
need_shutdown
|
||||||
|
fi
|
Loading…
Reference in New Issue
Block a user