镜像实现:

  • 密码注入
  • 修改密码
  • 根分区扩展

1、下载windows iso镜像

例如:cn_windows_server_2012_r2_vl_with_update_x64_dvd_4051059.iso
 
ISO镜像名解析:
Service Pack:直译是服务包,比较大的而且重要的升级补丁,修补系统、大型软件中的安全漏洞。
VL Build和Retail Build区别
1、主要在于销售方式和授权方式不同
  • VL Build:批量许可版本,同VL版,一般情况下是发布给企业集团的版本。
  • Retail Build:零售版本,一般情况下是面向个人零售市场。
2、安装方面:VL安装过程无需密码,零售版无密钥无法完成安装。
3、激活方面:VL版的可以用零售版的密钥激活,但是反过来不可以,所以通常是下载VL版的,减少一些不必要的麻烦。激活后,Retail Build与VL Build没有无区别获较少区别。

2、获取virtio-win.iso(包含一些硬件驱动和qemu-ga服务)、cloudbase-init

下载地址:
virtio-win.iso:  https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/stable-virtio/virtio-win.iso
cloudbase-init  https://github.com/openstack/cloudbase-init
关于virtio:
kvm因为使用了硬件虚拟化,所以其cpu方面的运行效率是很高的。不过,kvm在I/O虚拟化方面,传统的方式是利用QEMU纯软件的方式来模拟I/O设备,
这样每次虚机发起I/O请求的时候,KVM内核模块会捕获这次请求,然后处理后将其放入I/O共享页,并通知用户空间中运行的QEMU程序。
QEMU获得I/O操作,交由硬件模拟代码(Emulation)来模拟出本次I/O操作之后,将结果放回I/O共享页,同时通知KVM内核模块读取I/O共享页的操作结果,把结果返回给虚机。
由于这种方式每次I/O操作经过的路径很复杂,其效率很低。所以就提出了virtio这种方案,virtio其实就是一个运行于Hypervisor之上的api接口,
让客户机知道自己运行于虚拟化环境中,进行I/O操作的时候通过virtio与Hypervisor通信,从而是虚机有更好的性能。

3、创建镜像

创建一个qcow2格式的虚拟机磁盘文件
qemu-img create -f qcow2 windows2012.qcow2 20G

4、安装镜像

使用virt-install安装镜像

virt-install --connect qemu:///system \
--name windows2012 --ram 2048 --vcpus 2 \
--network network=default,model=virtio \
--disk path=windows2012.qcow2,format=qcow2,device=disk,bus=virtio \
--cdrom cn_windows_server_2012_r2_vl_with_update_x64_dvd_4051059.iso \
--disk path=/home/windows-image/virtio-win-0.1.126.iso,device=cdrom \
--vnc --os-type windows --os-variant win2k12r2
注意:
在物理机使用 osinfo-query os 命令查看对应版本的--os-variant值。
镜像创建的虚拟机启动不了,磁盘启动顺序出现问题,加载顺序错误,导致加载不了。
 
例如:可能是虚拟机的.xml文件中cn_windows_server_2012_r2_vl_with_update_x64_dvd_4051059.iso 标记为hdb,
而/home/windows-image/virtio-win-0.1.126.iso 标记为hda,
 
修改.xml文件,或者在virt-manager修改启动顺序

5、加载VirtIO Driver,安装磁盘驱动

默认情况下Windows检测不到可用的安装磁盘,我们需要先安装磁盘驱动。 
安装Win2k12R2时,选择【手动加载磁盘驱动】
浏览D:\viostor\2k8R2\amd64\viostor.inf
添加选中文件,点击【下一步】进行安装
 
注意:我们也可以在此步骤安装其他驱动,但是不推荐,
因为有些驱动系统检测不到,会被隐藏,需要去掉【隐藏与系统硬件不匹配的驱动】的对勾,
才能看到相应的.inf文件进行安装
 

6、系统安装、并重启几次(可能需要手动重启)

开机设置密码:windows2012

7、装其他virtio驱动、启动balloon服务

以管理员权限开启powershell,在命令行中安装virtio-win提供的各个驱动:
PCI简易通信控制器-安装vioserial驱动
内存控制器-安装Balloon驱动
网络适配器-安装NetKVM驱动
存储控制器-安装vioscsi驱动
#各个驱动安装操作一致,
#以netkvm为例:
cd C:\Windows\System32
pnputil -i -a D:\NetKVM\2k12r2\amd64\netkvm.inf

openstack windows2012r2 glance镜像制作-LMLPHP

关于PnPUtil:https://technet.microsoft.com/zh-cn/library/ff550419

openstack windows2012r2 glance镜像制作-LMLPHP

安装完后进设备管理器查看下驱动:
openstack windows2012r2 glance镜像制作-LMLPHP

驱动装完之后需要启动balloon服务(ceilometer采集虚拟机内存监控信息所用),
将virtio中的 balloon文件夹放到, c:\Program Files下(和qemu-ga安装目录位置相同即可),在命令行或者图形界面运行次程序,
确保服务启动和开机自启动
openstack windows2012r2 glance镜像制作-LMLPHP

openstack windows2012r2 glance镜像制作-LMLPHP

8、安装qemu-ga

在powershell安装qemu-ga:
openstack windows2012r2 glance镜像制作-LMLPHP

或者在gui使用鼠标安装:进入驱动D:\guest-agent\ ,双击安装64bit的qemu-ga即可。
 
启动qemu-ga的2个服务:
openstack windows2012r2 glance镜像制作-LMLPHP

9、安装cloudbase-init

 
为了cloudbase-init在实例启动时可以运行脚本,设置powershell执行策略为不受限制
C:\powershell
C:\Set-ExecutionPolicy Unrestricted

openstack windows2012r2 glance镜像制作-LMLPHP

下载地址:https://cloudbase.it/downloads/CloudbaseInitSetup_0_9_9_x64.msi

C:\Invoke-WebRequest -UseBasicParsing https://cloudbase.it/downloads/CloudbaseInitSetup_Stable_x64.msi -OutFile cloudbaseinit.msi
C:\.\cloudbaseinit.msi

安装参考:https://cloudbase.it/cloudbase-init/ 链接下的installation板块

安装过程中的几个需要配置的地方:

Username: Administrator
Network adapter to configure: Red Hat VirtIO Ethernet Adapter
Serial port for logging: COM1
 
注意:安装完成后,在最后的安装设置窗口选
run sysprep   和  Shutdown check boxes 
最后click Finish, 等待关机 

10、配置Cloudbase-init

cloud-init的一些功能设置可参考:
http://www.cloudbase.it/cloud-init-for-windows-instances/
配置文件参考:
[DEFAULT]
username=Administrator
groups=Administrators
inject_user_password=true
####network_adapter=Red Hat VirtIO Ethernet Adapter ####此项0..9版本,暂时没有
config_drive_raw_hhd=true
config_drive_cdrom=true
bsdtar_path=C:\Program Files (x86)\Cloudbase Solutions\Cloudbase-Init\bin\bsdtar.exe
verbose=true
debug=true
logdir=C:\Program Files (x86)\Cloudbase Solutions\Cloudbase-Init\log\
logfile=cloudbase-init.log
logging_serial_port_settings=COM1,,N,
mtu_use_dhcp_config=false
ntp_use_dhcp_config=false
local_scripts_path=C:\Program Files (x86)\Cloudbase Solutions\Cloudbase-Init\LocalScripts\
metadata_services=cloudbaseinit.metadata.services.configdrive.ConfigDriveService ###此项待验证
allow_reboot=false ###需要添加此项,禁止开机重启
stop_service_on_exit=false ###添加此项

11、开启远程桌面、关闭防火墙

 
本文参考链接:

Documentation: http://cloudbase-init.readthedocs.org/en/latest/

05-04 07:36