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