写在KVM (Kernel-based Virtual Machine) 安装成功后


为什么选择KVM?

1. 受制于VMWare Workstation版本的8GB磁盘文件限制
2. VMWare安装文件动则几百MB,更新麻烦
3. 被KVM虚拟机的性能吸引,可以看这个测试报告
Phoronix – Ubuntu 8.04 KVM Benchmarks
Phoronix – Intel Core i7 Virtualization Performance
4. 命令行配置——灵活

我的系统环境

软件环境:
主机操作系统:Linux leo-laptop 2.6.28-15-generic #48-Ubuntu SMP Wed Jul 29 08:53:35 UTC 2009 x86_64 GNU/Linux
客户机操作系统:Enterprise Linux Release 5 Update 3 Media Pack for x86_64(64 bit)
kvmqemu版本
QEMU PC emulator version 0.9.1
kvm-84

硬件环境
T7300,4GB RAM, Ext4

安装步骤

1.检查本机的CPU是否支持硬件虚拟化
如果能够找到包含vmx,svm字样,则CPU支持虚拟化
Intel CPU
grep vmx /proc/cpuinfo
AMD CPU
grep svm /proc/cpuinfo
如果CPU支持,还需要在BIOS打开虚拟化支持。通常,主板默认关闭这个选项

2. 安装软件
sudo apt-get install kvm qemu bridge-utils uml-utilities

3. 装载模块
sudo modprobe kvm
装载Intel模块
sudo modprobe kvm-intel
装载AMD模块
sudo modprobe kvm-amd

4. 添加你当前的帐户到kvm
sudo addgroup ‘leo’ kvm

5. 创建磁盘镜像文件
kvm-img create -f qcow2 vm.img 10G

-f表示以什么格式创建磁盘镜像文件,推荐选择qcow2格式,在很多网上教程中都选择的是qcow格式。我在使用qcow格式的镜像文件安装REHL5U3的时候,写这个文件出奇的慢,换成qcow2就可以了。其他的格式还有raw,这种格式要求文件系统能够支持预分配空间,例如ext2,ext3,ext4,NTFS等等,所谓的预分配技术就是在创建文件的时候就把文件的空间全部分配好,和qcow2按需分配不同,这样能够提高虚拟机的磁盘性能。

6. 安装系统
使用ISO文件的时候
kvm -hda vm.img -cdrom cdrom.iso -m 256M -net nic -net user

直接从光驱安装
kvm -hda r5u3.img -cdrom /dev/dvd -m 256M -net nic -net user

-net nic -net user配置虚拟系统使用NAT方式访问网络,在这种方式下,虚拟系统和主机系统不在同一个网段内,互相访问及其不方便,后面会提供桥接网络的配置方法

iso文件创建的时侯很简单,看下面的命令
dd if=/dev/dvd of=rehl.iso

7. 启动系统
这块我们创建一个脚本,以后每次启动虚拟机的时候就不用再键入长长的命令了。

StartRHEL5U3.sh
#!/bin/bash
kvm -M pc -hda r5u3.img
-m 1500M
-smp 2
-net nic,macaddr=DE:AD:BE:EF:27:20
-net user
-usb
-localtime
-usbdevice tablet
-soundhw all

-hda 指明磁盘镜像的挂载方式
-m 1024 给虚拟机分配1G内存
-smp 2 指明使用的CPU数量
-localtime 使用主机系统时间设置虚拟系统时间
-usb 使USB设备可用
-usbdevice tablet 使坐标设备可用,例如触摸版,实验表明我的USB鼠标在没有增加这个选项的时候,出现跳动的现象,添加了之后就没有问题
-soundhw all 使声音设备可用,如果你知道设备类型,也可以指定,具体的可以参考man
其他,关于-vga选项,kvm默认使用cirrus显卡从Windows 95开始的所有版本都能正常使用这个卡,但是在这种模式下最高分辨率也只有800×600,如果要想有更高的分辨率,需要使用其他选项

8. 设置系统启动时自动加载模块
如果上面的都正常了之后,在/etc/modules中添加下面两行,使系统启动的时候自动读入kvm,kvm-intel模块
kvm
kvm-intel
或者
kvm
kvm-amd

10. 配置bridge网络模式(桥接网络模式),
配置bridge网络模式(桥接网络模式),bridge-utils目前仅仅支持有线网卡桥接网络模式,不支持无线网卡
默认安装完了之后,会在/etc/kvm/下存在一个kvm-ifup文件,但是kvm启动的时候并不读取这个文件。而是读取/etc/kvm-ifup和/etc/kvm-ifdown文件,所以我们在/etc目录下创建这两个文件

文件的权限:
ls -l /etc/kvm-if*
-rwxr-xr-x 1 root root 503 2009-08-17 22:32 /etc/kvm-ifdown
-rwxr-xr-x 1 root root 1063 2009-08-17 22:28 /etc/kvm-ifup

/etc/kvm-ifup文件内容:
#!/bin/bash
# NOTE: 这个脚本在虚拟系统启动的时候执行,设置主机网桥
# 虚拟系统启动后,还需要设置和网桥IP在同一个网段的IP才能实现虚拟系统
# 和主机所在网络其他系统之间的相互访问
# 获取主系统的IP和网关
# 关于`grep “inet 地址”`和`sed ‘s/地址://`根据系统语言的不同,填写中文或者英文,
# 详细的可以根据ifconfig eth0的结果来修改# 和主机所在网络其他系统之间的相互访问
# 获取主系统的IP和网关
# 关于`grep “inet 地址”`和`sed ‘s/地址://`根据系统语言的不同,填写中文或者英文,
# 详细的可以根据ifconfig eth0的结果来修改
IP=`ifconfig eth0|grep “inet 地址”|awk ‘{print $2}’|sed ‘s/地址://’`
GATEWAY=`route -n|grep ^0.0.0.0|awk ‘{print $2}’`
BRIDGE=br0
ETHDEV=eth0
# 删除eth0的IP地址
/sbin/ip addr del $IP dev $ETHDEV &> /dev/null
# 创建tap接口,并激活
/usr/sbin/tunctl -u leo -t $1 &> /dev/null
/sbin/ip link set $1 up
# 添加网桥接口,并将eth0加入到网桥
/usr/sbin/brctl addbr $BRIDGE
/usr/sbin/brctl addif $BRIDGE $ETHDEV
# 将tap0加入网桥
/usr/sbin/brctl addif $BRIDGE $1
# 设置IP地址,启动网桥
/sbin/ifconfig $BRIDGE $IP up
# 添加默认路由
/sbin/route add default gw $GATEWAY

/etc/kvm-ifdown文件内容:
#!/bin/sh
# NOTE: 这个脚本在虚拟机关闭的时候执行,删除网桥,恢复主机网卡IP地址
#
IP=`ifconfig br0|grep “inet 地址”|awk ‘{print $2}’|sed ‘s/地址://’`
GATEWAY=`route -n|grep ^0.0.0.0|awk ‘{print $2}’`
BRIDGE=br0
ETHDEV=eth0
# 删除br0的IP地址
/sbin/ip addr del $IP dev $BRIDGE &> /dev/null
# 禁用br0
/sbin/ip link set $BRIDGE down
# 删除网桥
/usr/sbin/brctl delbr $BRIDGE
/sbin/ifconfig $ETHDEV $IP up &> /dev/null
/sbin/route add default gw $GATEWAY

11. 修改启动脚本,使用sudo -s 切换到root shell,然后启动虚拟系统
kvm -M pc -hda r5u3.img
-m 1500M
-smp 2
-net nic,macaddr=DE:AD:BE:EF:27:20
-net tap
-usb
-localtime
-usbdevice tablet
-soundhw all
如果没有使用root权限启动虚拟机,则会提示
warning: could not configure /dev/net/tun: no virtual network emulation
Could not initialize device ‘tap’

12. 系统启动之后,主机的网络情况:
br0 inet 地址:192.168.0.84 广播:192.168.0.255 掩码:255.255.255.0
eth0 无IP
tap1 无IP

13. 虚拟系统的网络情况:
eth0 inet 地址:192.168.0.10 广播:192.168.0.255 掩码:255.255.255.0
至此KVM的基本配置已经完成
常用快捷键
ctrl + alt + f 全屏模式,或者返回正常模式
ctrl + alt 虚拟系统锁定鼠标或者释放鼠标

参考:

https://wiki.ubuntu.com/kvm
http://www.linux-kvm.org/page/Networking
http://linux.chinaunix.net/bbs/viewthread.php?tid=788174

碰到过的问题:

1. 使用kvm启动虚拟系统的时候,如果使用了-net tap参数,则虚拟机不能正常启动,出现下面的错误
Could not initialize device ‘tap’
使用root帐号启动虚拟机,该问题解决。

2. 使用qemu-system-x86_64启动虚拟系统时,出现
MP-BIOS bug: 8254 timer not connected to IO-APIC
在安装的时候键入下面的命令
linux initrd=initrd.img BOOT_IMAGE=vmlinuz noapic
安装好了之后在menu.lst里添加noapic参数即可

3. 在使用kvm命令正在运行虚拟系统时,如果在其他的终端里执行了kvm相关的命令,虚拟系统会异常终止,在使用exit命令退出root shell时,会再次启动虚拟系统,这时,关闭即可。异常中断虚拟系统,由于没有正常调用/etc/kvm-ifdown脚本,会导致主机网络不能正常使用,手动执行一下kvm-ifdown里面的命令即可,确保网桥已经删除,主机网卡正确获得ip地址,如果还是不能正常启动,用下面的命令重新激活一下网卡:
sudo ip link set eth0 down
sudo ip link set eth0 up

4. 使用qemu-system-x86_64启动虚拟系统,效率及其低下,换用kvm启动虚拟系统及OK。

未解决的问题:

1. 必须使用root身份启动kvm才能使用桥接网络模式
2. 使用bridge-utils提供的网络桥接目前不支持无线网卡,发现parprouted可以支持无线网卡桥接,等待试验
3. 目前的启动脚本中对网络的配置只能支持单个虚拟系统,计划改善脚本,实现多虚拟支持
4. 磁盘镜像文件扩大,删除虚拟系统中的文件之后,磁盘镜像文件并不会缩小。解决方法已经在http://cha.homeip.net/blog/archives/2009/02/kernelbased_vir.html找到,等待试验(在winxp虚拟机中,按照该帖的方法试验,磁盘空间未能缩小)

Advertisements

发表评论

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out / 更改 )

Twitter picture

You are commenting using your Twitter account. Log Out / 更改 )

Facebook photo

You are commenting using your Facebook account. Log Out / 更改 )

Google+ photo

You are commenting using your Google+ account. Log Out / 更改 )

Connecting to %s