热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

在KVM虚拟机中安装WindowsServer2008R2并激活

在一台DELLR310的宿主机上安装了UbuntuServer12.10默认集成KVM虚拟机,用户态虚拟机软件qemu-kvm使用seabios的作为bios实现(位于/usr/share/qemu-kvm/bios.bin,来自于qemu-common1.2.0+noroms-0ubuntu2),该bios.bin仅

在一台DELL R310的宿主机上安装了Ubuntu Server
12.10默认集成KVM虚拟机,用户态虚拟机软件qemu-kvm使用seabios的作为bios实现(位于
/usr/share/qemu-kvm/bios.bin,来自于qemu-common
1.2.0+noroms-0ubuntu2),该bios.bin仅包含部分来自宿主机的SLIC信息,但不完整,无法通过Window
OEM验证。

本文将介绍安装KVM虚拟机,借助virt-install安装Windows客户机,去除bios.bin里内置的SLIC,然后使用-acpitable参数载入正确的SLIc 2.1信息,导入OEM证书和OEM key激活Windows。

由于Ubuntu Server没有安装图形环境,DELL R310服务器也是不带显示器的,所有windows的安装过程是通过本来的Macbook Air的VNC客户端操作的。

安装KVM虚拟机

首先检查你的处理器是否支持硬件虚拟化;如果支持,下面这个命令

$ sudo egrep '(vmx|svm)' --color=always /proc/cpuinfo

会看到如下类似信息

flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca
cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe
syscall nx rdtscp lm constant_tsc arch_perfmon pebs bts rep_good
nopl xtopology nonstop_tsc aperfmperf pni dtes64 monitor ds_cpl
vmx smx est tm2 ssse3 cx16 xtpr pdcm sse4_1 sse4_2
popcnt lahf_lm ida dtherm tpr_shadow vnmi flexpriority ept vpid

若什么都没有显示,那么你的处理器不支持硬件虚拟化,就此打住,不要往下折腾了。

检查bios虚拟化开关是否开启

$ sudo kvm-ok

正确的返回如下

INFO: /dev/kvm exists
KVM acceleration can be used

安装KVM,(若在Ubuntu Server安装过程中已经安装了KVM忽略此步骤)

$ sudo apt-get install ubuntu-virt-server  kvm-ipxe

之后,将当前用户添加到libvirtd群组

$ sudo adduser `id -un` libvirtd
$ sudo adduser `id -un` kvm

你需要要重新登录一下,才能让新群组生效。

验证kvm是否成功安装

cloud03@cloud03:~$ virsh -c qemu:///system list
 Id    Name                           State
----------------------------------------------------
cloud03@cloud03:~$
安装Windows Server 2008 R2 准备

Windows Server 2008 R2 安装镜像ISO

Windows VirtIO Drivers,若不加载该驱动windows installer会无法找到虚拟磁盘(没有验证过,网上是怎么说的) 点击下载:virtio-win-0.1-30.iso

安装virt-install $ sudo apt-get install virtinst

开始安装
$ virt-install --connect qemu:///system --arch=x86_64 -n win2k8 -r 4096 --vcpus=2 \
-c /home/cloud03/cn_windows_server_2008_r2_standard_enterprise_datacenter_and_web_with_sp1_vl_build_x64_dvd_617396.iso \
--noautoconsole --os-type windows --os-variant win2k8 \
--disk path=/home/cloud03/virtio-win-0.1-30.iso,device=cdrom,perms=ro \
--disk path=/var/lib/libvirt/images/win2k8.img,size=50 \
--graphics vnc,password=foobar,listen=0.0.0.0

部分参数说明

-n win2k8 虚拟机的名称为win2k8

-r 4096 分配4G内存

-vcpus=2 两个cpu

-c /home/cloud03/cn_windows…617396.iso 指向ISO安装镜像位置

?disk path=/home/cloud03/virtio-win-0.1-30.iso,device=cdrom,perms=ro 加载virtio驱动

?disk path=/var/lib/libvirt/images/win2k8.img,size=50 创建虚拟磁盘,并分配50G的空间

?graphics vnc,password=foobar,listen=0.0.0.0 开启VNC,password选项是为了兼容mac内置Screen Sharing VNC终端无法连接不加密的VNC Server,listen选项是为了让VNC终端在所有IP地址上都开启监听,默认在127.0.0.1上监听,仅适用于本机VNC终端访问。

使用VNC客户端打开远程桌面,Mac下非常简单,在Terminal.app里输入open vnc://192.168.18.130回车即可。windows和linux桌面系统请自行安装vnc客户端。

另外不少网友推荐Mac下用Chicken of the VNC.app,试用过后不如内置Screen Sharing好,特别是系统重启断线重连的时候内置的客户端表现很稳定,Chicken of the VNC会假死,需要退出程序重开。

编译bios.bin

seaslic 项目对seabios项目打了一个patch用于解决预安装正版windows的宿主机,改装linux运行kvm后,让虚拟机bios也有和宿主机一样的SLIc。简单的说就是把宿主机bios里的SLIc信息导入到虚拟机的bios.bin文件中去。让虚拟机也有正确的OEM标识。

经过测试seaslic项目导入的SLIc信息不完整,(至少在DELL R310下是不完整的),无法通过windows校验。

qemu-kvm有一个-acpitable选项,可以通过file=… 装载一个外部的SLIC文件(SLIC 2.1 BINS 1-31-2011.7z) 这里几乎有所有OEM机器的SLIC文件和证书)。

但是如果直接使用-acpitable选项加载外部SLIC进BIOS无论是使用内置的bios.bin(/usr/share/qemu-kvm/bios.bin),还是seaslic项目打过Patch的bios.bin都会导致ACPI table里有两条SLIc记录,一条正确的一条不完整的,导致windows无法激活。

一个可行的方案:在sealic项目的基础上,稍作修改编译一个完全不包含SLIc的bios.bin,然后在结合-acpitable选项载入外部SLIC文件。经实践,可以激活。

具体步骤如下:

下载sealic项目源码

$ cd ~
$ git clone git://github.com/ghuntley/seaslic

执行./patch.sh,该脚本会运用patch然后编译出bios.bin,调用该脚本只需要其运用patch的功能,编译出来的bios.bin先别管。

$ cd seaslic
$ ./patch.sh

编辑acpi.c文件

$ vim  seabios.submodule/src/acpi.c

注释掉638-647行,

/*#ifdef CONFIG_OEM_SLIC
{ void *buf = malloc_high(sizeof(SLIC));
  if (!buf)
    warn_noalloc();
  else {
    memcpy(buf, SLIC, sizeof(SLIC));
    ACPI_INIT_TABLE(buf);
  }
}
#endif*/

然后编译

$ cd seabios.submodule
$ make

替换系统内置bios.bin

$ sudo cp out/bios.bin /usr/share/qemu-kvm/bios.bin
修改虚拟机配置

使用virsh edit命令可以修改虚拟机的配置。

$ virsh edit win2k8

将第一行


改成


然后,在靠近文件的末尾处,便签之后,加入如下内容


    
    

保存退出。其中,SLIC-DELL-PE_SC3-2.1.BIN文件可以从SLIC 2.1 BINS 1-31-2011.7z找到。

重启虚拟机,然后在虚拟机下载windows工具SLIC Toolkit.若“SLIC诊断”栏显示SLIC状态为验证通过则表明已生效。

在Windows里安装OEM证书和序列号

现在是完事具备只欠东风了,从SLIC 2.1 BINS 1-31-2011.7z压缩包中可以找到DEL的OEM证书。

在windows控制台中使用如下命令导入

> slmgr -ilc DELL-DELL-2.0.XRM-MS

然后在这里Server 2008/Server 2008 R2 OEM SLP Keys找到对应的Key。使用下面的命令导入

> slmgr -ipk D7TCH-6P8JP-KRG4P-VJKYY-P9GFF

Server 2008 R2 Standard DELL OEM KEY
D7TCH-6P8JP-KRG4P-VJKYY-P9GFF
Server 2008 R2 Enterprise DELL OEM KEY
BKCJJ-J6G9Y-4P7YF-8D4J7-7TCWD

重新打开SLIC Toolkit工具,若“序列号与证书验证及备份”栏显示证书正确,那表示已经大功告成。


推荐阅读
  • 解决微信电脑版无法刷朋友圈问题:使用安卓远程投屏方案
    在工作期间想要浏览微信和朋友圈却不太方便?虽然微信电脑版目前不支持直接刷朋友圈,但通过远程投屏技术,可以轻松实现在电脑上操作安卓设备的功能。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 本文介绍如何在Linux Mint系统上搭建Rust开发环境,包括安装IntelliJ IDEA、Rust工具链及必要的插件。通过详细步骤,帮助开发者快速上手。 ... [详细]
  • 优化联通光猫DNS服务器设置
    本文详细介绍了如何为联通光猫配置DNS服务器地址,以提高网络解析效率和访问体验。通过智能线路解析功能,域名解析可以根据访问者的IP来源和类型进行差异化处理,从而实现更优的网络性能。 ... [详细]
  • 在 Windows 10 中,F1 至 F12 键默认设置为快捷功能键。本文将介绍几种有效方法来禁用这些快捷键,并恢复其标准功能键的作用。请注意,部分笔记本电脑的快捷键可能无法完全关闭。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本文介绍如何通过SSH协议使用Xshell远程连接到Ubuntu系统。为了实现这一目标,需要确保Ubuntu系统已安装并配置好SSH服务器,并保证网络连通性。 ... [详细]
author-avatar
UJXo小妖春日望美
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有