逻辑卷在启动时处于非活动状态

zer*_*021 10 linux lvm initramfs

我调整了逻辑卷和文件系统的大小,一切都很顺利。我安装了新内核,重启后我既不能启动当前内核,也不能启动以前的内核。选择 grub(2) 选项后出现未找到卷组错误。从繁忙的盒子中检查显示卷未注册到设备映射器并且它们处于非活动状态。激活后我无法挂载它们,我收到文件未找到错误(挂载 /dev/mapper/all-root /mnt)。

任何想法如何在启动时继续或使它们处于活动状态?或者为什么卷在启动时突然不活动?

问候,

马立克

编辑:进一步调查显示,这与调整逻辑卷的大小无关。启动失败后必须在 ash shell 中手动激活逻辑卷这一事实以及此问题的可能解决方案在我下面的回复中有所介绍。

zer*_*021 6

所以我最终设法解决了这个问题。检测逻辑卷存在问题(错误),这是某种竞争条件(在我的情况下,这可能发生在 KVM 内部)。这将在以下讨论中讨论。在我的特殊情况下(Debian Squeeze),解决方案如下:

  • 备份脚本 /usr/share/initramfs-tools/scripts/local-top/lvm2
  • 应用上述错误报告中的补丁
  • 运行 update-initramfs -u

这对我有帮助,希望它会帮助其他人(奇怪的是,这还不是主流的一部分)。

补丁链接:_http://bugs.debian.org/cgi-bin/bugreport.cgi?msg=10;filename=lvm2_wait-lvm.patch;att=1;bug=568838

以下是供后人使用的副本。

--- /usr/share/initramfs-tools/scripts/local-top/lvm2 2009-08-17 19:28:09.000000000 +0200
+++ /usr/share/initramfs-tools/scripts/local-top/lvm2 2010-02-19 23:22:14.000000000 +0100
@@ -45,12 +45,30 @@

  eval $(dmsetup splitname --nameprefixes --noheadings --rows "$dev")

- if [ "$DM_VG_NAME" ] && [ "$DM_LV_NAME" ]; then
-   lvm lvchange -aly --ignorelockingfailure "$DM_VG_NAME/$DM_LV_NAME"
-   rc=$?
-   if [ $rc = 5 ]; then
-     echo "Unable to find LVM volume $DM_VG_NAME/$DM_LV_NAME"
-   fi
+ # Make sure that we have non-empty volume group and logical volume
+ if [ -z "$DM_VG_NAME" ] || [ -z "$DM_LV_NAME" ]; then
+   return 1
+ fi
+
+ # If the logical volume hasn't shown up yet, give it a little while
+ # to deal with LVM on removable devices (inspired from scripts/local)
+ fulldev="/dev/$DM_VG_NAME/$DM_LV_NAME"
+ if [ -z "`lvm lvscan -a --ignorelockingfailure |grep $fulldev`" ]; then
+   # Use default root delay
+   slumber=$(( ${ROOTDELAY:-180} * 10 ))
+
+   while [ -z "`lvm lvscan -a --ignorelockingfailure |grep $fulldev`" ]; do
+     /bin/sleep 0.1
+     slumber=$(( ${slumber} - 1 ))
+     [ ${slumber} -gt 0 ] || break
+   done
+ fi
+
+ # Activate logical volume
+ lvm lvchange -aly --ignorelockingfailure "$DM_VG_NAME/$DM_LV_NAME"
+ rc=$?
+ if [ $rc = 5 ]; then
+   echo "Unable to find LVM volume $DM_VG_NAME/$DM_LV_NAME"
  fi
 }
Run Code Online (Sandbox Code Playgroud)


小智 5

创建一个/etc/init.d/lvm包含以下内容的启动脚本:

#!/bin/sh

case "$1" in
 start)
    /sbin/vgscan
    /sbin/vgchange -ay
    ;;
  stop)
    /sbin/vgchange -an
    ;;
  restart|force-reload)
    ;;
esac

exit 0
Run Code Online (Sandbox Code Playgroud)

然后执行命令:

chmod 0755 /etc/init.d/lvm
update-rc.d lvm start 26 S . stop 82 1 .
Run Code Online (Sandbox Code Playgroud)

应该为 Debian 系统解决问题。

  • 对于那些像我一样想知道的人,“vgscan”搜索系统上的卷组,而“vgchange -a”使卷组可用(“-ay”)或不可用(“-an”)。 (3认同)