我需要 GRUB 专家的一点帮助。
我刚刚将 1 TB 希捷硬盘克隆到全新的 2 TB 日立硬盘上,在更换硬盘之前,我决定对其进行启动测试。它通过 SATA 2 转 USB 适配器连接到我的电脑。25 小时的克隆操作似乎进展顺利;我使用了通过 pv 传输的 dd。
但是,当我启动时,我现在收到一条来自 GRUB2 的消息,说未找到分区;然后转储到 grub 救援提示符。
ls 为我提供了 hd0 上的一个分区驱动器(不确定这是什么,可能是拇指驱动器)、hd1 上的一系列分区以及 hd2 上的单个分区(同样,不知道这是什么)。(hd1,msdos10) 似乎是我保留的一个不可引导分区;大多数其他分区(ext 文件系统上的分区)都可以识别。我在 (hd1,msdos5) 上找到了我的 Ubuntu Trusty Tahr 根目录。但是,即使在“set root=(hd1,msdos5)”之后,所有 insmod 尝试(“insmod normal”)和(“insmod linux”)都返回“未找到分区”。
我猜想我的新驱动器的 MBR 与克隆到其上的分区无关。我不确定如何修复它。同样,目标驱动器安装在外部(即使它最终是内部驱动器);我可以启动到 LiveUSB 或 hda,但不能启动它。它有一个 Windows 7 分区、Ubuntu 14.04 和一系列附加分区,包括 Windows 恢复/修复/无论它们叫什么,我最后的额外分区、我的主分区、交换分区,可能还有一两个其他分区,如临时分区。
在最坏的情况下,我想我可以重新安装整个 Ubuntu 14.04,但这需要花费大量时间仔细检查存储库才能恢复所有旧内容。我确信这很简单,但除非绝对必要,否则我不会乱动 MBR,尤其是当我不知道自己在做什么并且可能需要 25 小时才能修复时!
引用 GRUB 的终端输出:
ls
> (hd0) (hd0,msdos3) (hd0,msdos2) (hd0,msdos1) (hd1) (hd1,msdos11) (hd1,msdos10) (hd1,msdos9) (hd1,msdos8) (hd1,msdos7) (hd1,msdos6) (hd1,msdos5) (hd1,msdos3) (hd1,msdos2) (hd1,msdos1) (hd2) (hd2,msdos1)
ls (hd0,1)
> Filesystem is unknown
ls (hd0,msdos1)
> Filesystem is unknown
set root=(hd1,msdos5)
insmod normal
> Partition not found
...
答案1
听起来好像新驱动器没有正确的分区 - 如果您只看到一个分区。您是否传递了 dd 命令“/dev/sdn”或“/dev'sdn1”进行写入?我认为您现在的首要任务是移除新驱动器,看看是否需要撤消 MBR“修复” - 如果需要,这里有几个问题和答案比如这个。
一旦你有了一个可以运行的系统,你就会知道‘如何正确地做到这一点’:
备份很好——你现在可能不需要提醒:)
首先,我将从实时 CD 启动开始,因为实时系统在写入时可能会发生变化 - 事实上几乎肯定会发生变化。
首先,检查旧驱动器(源)的位置,然后插入新驱动器,检查它去了哪里,因为驱动器名称可能会有所不同 -dmesg | tail
或者mount
会有所不同(但只有在文件系统识别它时才会挂载 - 我怀疑你的现在不会),或者fdisk -l
但需要小心才能正确完成。这是关键点!
一旦您知道哪个是哪个,您就可以进行复制;
dd if=/dev/sdx of=/dev/sdy
- 请注意,您不要使用分区号。
你可以使用pv
,但恕我直言,如果你遇到麻烦,这会让事情变得复杂,你已经知道这需要很长时间。如果你直接插入驱动器,速度会快得多。
您最终应该会得到 2 个相同的驱动器,其中一个有 50% 的未分配空间。断开新驱动器的连接,重新启动以确保一切正常。这在技术上不是必需的,但我会……
关机,插入新驱动器 - 直接插入或再次使用 USB 连接即可。重新启动。如果无法启动,则表示您的 PC 正在将 /dev/sda 分配给新驱动器,因此现在使用 USB 可能是一个不错的计划。
在此阶段,您可以使用gparted
扩大现有分区,或使用 fdisk 添加新分区。完成后,您可以交换驱动器并尝试启动;您可能需要返回顶部并尝试我提供的链接来修复启动,具体取决于您所做的更改。