最近,由于电源故障,我的 XFS 文件系统损坏了。(CentOS 7 系统)。系统无法正常启动。
我从救援 CD 启动并尝试xfs_repair
,它告诉我挂载分区来处理日志。
我安装了该分区,并执行了ls
验证,它确实在那里。我卸载了该分区并xfs_repair
再次尝试,结果得到了同样的消息。
在这种情况下我该怎么办?我的救援 CD(系统救援 CD,版本 4.7.1)有问题吗?我是否应该使用其他程序?
我最终只是从备份中恢复了系统(在这种情况下,它快速而简单),但我想知道将来该怎么做。
答案1
如果你试图跑步xfs_repair,得到建议挂载文件系统重放日志的错误消息,并且在挂载之后仍然收到相同的错误消息,则可能需要执行强制修复(使用-L
带有的标志xfs_repair
)。这个选项应该是最后的手段。
例如,我将使用在 CentOS 7 安装中根分区损坏的情况。尝试挂载分区时,我不断收到以下错误消息:
mount:将 /dev/mapper/centos-root 挂载到 /mnt/centos-root 失败:结构需要清理
不幸的是,强制修复需要在尝试修复之前将日志清零(销毁)。使用此方法时,最终可能会出现比最初预期更多的损坏数据;但是,我们可以使用适当的 xfs 工具查看可能造成何种损坏,然后再进行任何永久性更改。
使用xfs_metadump和xfs_mdrestore,您可以创建受影响分区的元数据映像,然后对映像而不是分区本身执行强制修复。这样做的好处是能够在分区上执行强制修复之前查看强制修复带来的损坏。
为此,您需要一个大小合适的 USB 或外部硬盘。首先安装 USB 驱动器 - 我的 USB 位于/dev/sdb1
,您的 USB 可能名称不同。
mkdir -p /mnt/usb
mount /dev/sdb1 /mnt/usb
安装后,运行xfs_metadump
以将分区元数据的副本创建到 USB - 同样,受影响的分区可能会有所不同。在这种情况下,我有一个损坏的根分区,位于/dev/mapper/centos-root
:
xfs_metadump /dev/mapper/centos-root /mnt/usb/centos-root.metadump
接下来,您需要将元数据恢复到图像中,以便我们可以进行修复并测量损坏程度。
xfs_mdrestore /mnt/usb/centos-root.metadump /mnt/usb/centos-root.img
我发现救援模式xfs_mdrestore
不可用,而是需要处于实时 CentOS CD 的救援模式。
最后,我们可以对图像进行修复:
xfs_repair -L /mnt/usb/centos-root.img
修复完成并评估输出和潜在损坏后,您可以确定是否要对分区执行修复。
要对分区运行修复,只需运行:
xfs_repair -L /dev/mapper/centos-root
不要忘记检查其他分区是否损坏。修复后,重新启动系统,您应该能够成功启动。
-L
请记住,当没有其他可以修复的选项时,该标志应作为最后的手段。
我发现这些在线文章很有帮助:
答案2
当 centos 7 在 kvm 虚拟机中停止运行的时候,我遇到了这个错误:
# metadata corruption detected at xfs...
当我使用带有的日志时journalctl -xe
,我发现安装时出现错误:
# /dev/mapper/root /sysroot
我使用以下方法解决:
# xfs_repair /dev/mapper/root
然后系统完成七个阶段,然后使用
# ./shutdown
然后虚拟机centos 7就可以正常工作了……
问候
注意:也许你的设备/dev/mapper/root
有其他名称,请查看错误日志以journalctl -xe
找到安装错误的设备名称