VMWare虚拟机迁移到Hyper-v虚拟机加载不了系统

前一段时间在测试服务器上部署一个公司的小应用系统,服务器用的是 Windows 2008 R2。虚拟机文件是 VMWare的,用工具将其转换为 Hyper-V 的磁盘镜像,然后添加到一个新建的虚拟机里。但是明明可以在 VMWare 里正常启动的 CentOS 7,却死活起不来,总是进入 dracut 的 shell 里去。

症状:
    [ OK ] Reached target Paths.
    [ OK ] Reached target Basic System.
    Starting File System Check on /dev/mapper/centos-root…
    systemd-fsck[288]: fsck: error 2 (No such file or directory) while executing fsck.ext2 for /dev/mapper/centos-root
    [ OK ] Started File System Check on /dev/mapper/centos-root
    dracut-initqueue[250]: Warning: Could not boot
    dracut-initqueue[250]: Warning: /dev/centos/root does not exist
    dracut-initqueue[250]: Warning: /dev/centos/swap does not exist
    dracut-initqueue[250]: Warning: /dev/mapper/centos-root does not exist
    Starting Dracut Emergency Shell…
    Warning: /dev/centos/root does not exist
    Warning: /dev/centos/swap does not exist
    Warning: /dev/mapper/centos-root does not exist
    Generating “/run/initramfs/rdsosreport.txt”

  cd /dev 然后 ls 了一下,发现竟然没有开头 hd 或 sd 的硬盘设备。在网上 百度与Google 了一下,只找到一堆问同样问题的,却没有几个靠谱的回答。于是只好自己想办法。
  首先想到 VMWare 里的虚拟硬盘是挂载在 SCSI 控制器下的,而 Hyper-V 里却自动挂到了 IDE 控制器下。于是添加了一个 SCSI 控制器,把 .VHD 磁盘文件重新挂到它下面。结果连 GRUB 都没影了:
    Boot failure. Reboot and Select proper Boot device or Insert Boot Media in selected Boot Device

  查了一下,第一代 Hyper-V 虚拟机竟然不支持从 SCSI 硬盘启动!晕,而且微软的工程师还写了一篇博客 Why Hyper-V cannot boot off of SCSI disks (and why you should not care) 来解(jiǎo)释(biàn)。只好又改回去。
  仔细想了一下,应该是 dracut 缺少 IDE 控制器的驱动,依照以前解决 NVIDIA 显卡驱动和内核自带的 nouveau 驱动冲突的方法,重建了一下 initramfs,果然可以进系统了!

处理方法:
1、用 CentOS 7 安装光盘启动,并在引导菜单中选择 troubleshooting -> Rescue a Linux OS,之后按 continue 进入恢复命令行。
2、切换到要修复的系统根路径:cd /mnt/sysimage 然后 chroot .
3、备份一下之前的文件:
mv /boot/initramfs-$(uname -r).img /boot/initramfs-$(uname -r).img.bak
4、重建 initramfs:
dracut -v /boot/initramfs-$(uname -r).img $(uname -r)
Linux 不兼容 Secret Boot

  另外,Windows Server 2012 R2 引入了第二代 Hyper-V 虚拟机。这回支持从 SCSI 硬盘引导了。 微软的 John Howard 还写了一个系列的文章 Hyper-V generation 2 virtual machines。
  新一代的虚拟机中,默认开启了 Secret Boot,会校验 bootloader 的数字签名。大多数 Linux 发行版都不支持这个机制。所以应该在虚拟机设置里关掉它,或者干脆使用第一代虚拟机(在创建向导中选择)。

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值