一 KVM虚拟机简介
KVM是kernel-based Virtual Machine的简称目前已成为学术界的主流VMM之一。KVM的虚拟化需要硬件支持如Intel VT技术或者AMD V技术)是基于硬件的完全虚拟化。KVM的安装和使用相对于XEN来说十分的简单和方便并且功能强大比较适用于高性能计算服务的云计算环境中作为IAAS层的虚拟化部署工作。不得不提的是甲骨文公司的VirtualBox也很强大各方面与KVM可以相媲美但是现在不开源比较昂贵一般的云计算平台很少使用。至于完全虚拟化和半虚拟化我觉得这是一个很模糊的概念。
KVM提供了图像界面的管理接口(Virtual Machine Manager)和命令行式的管理接口virsh。可以根据使用的场景采用不同的方式当然也可以使用Libvirt库进行管理虚拟机并且使用libvirt库进行虚拟机的管理是业界很推崇的做法这都源于libvirt库良好的移植性和强大的API并且提供了多种语言接口如C语言python语言JAVA语言C#语言和PHP语言能对XenKVM以及QEMU等多类虚拟机进行管理管理。详情请参考其官网http://libvirt.org/。
二 安装KVM虚拟机管理软件/模块 以下都是在宿主操作系统CentOS6.2中操作完成
在BIOS里将VT打开在物理机上安装宿主操作系统CentOS6.2时一般可以选择虚拟化技术支持会自动安装KVM虚拟机管理软件的。如果没有安装可以参考以下步骤
1产看物理机主要是CPU是否支持虚拟机技术
通过以下命令查看注意xen和kvm不能共存在带xen内核的系统中使用下面的命令会无效即使你的机器支持VT技术也不会查到vmx或者svm
[root@centoskvm ~]# egrep '(vmx|svm)' --color=always /proc/cpuinfo
输出内容不为空则说明支持kvm虚拟技术。
2安装KVM
使用yum在线安装KVM的主要组件及工具
[root@centoskvm ~]# yum install kvm kmod-kvm kvm-qemu-img libvirt Python-virtinst virt-manager virt-viewer bridge-utils -y //可能某些软件包没有没关系看下面测试
安装完成后重启主机
[root@centoskvm ~]# reboot
重启完成后检查kvm模块是否加载
[root@centoskvm ~]# lsmod | grep kvm kvm_intel 50380 4 kvm 305081 1 kvm_intel
显示结果如上表示kvm模块已经加载如果没有输出信息则表示没有加载成功。
三 配置KVM虚拟机运行的网络环境
1说明
KVM默认是使用NAT模式为虚拟机客户操作系统提供网络的还有一种网络模式叫做桥接模式。至于它的网络环境管理后面将会有文章专门介绍本文就先以桥接模式配置网络环境来安装虚拟机。
2宿主操作系统的网络配置文件如下(/etc/sysconfig/network 和 /etc/resolv.conf文件可以不考虑 )
添加网桥br0配置文件如下
[root@lw-01 network-scripts]# cat ifcfg-eth0 DEVICE=eth0 ONBOOT=yes HWADDR=00:0C:29:B1:DE:85 BRIDGE=br0 // 其它都注释掉
[root@lw-01 network-scripts]# cat ifcfg-br0 DEVICE=br0 TYPE=Bridge ONBOOT=yes BOOTPROTO=static IPADDR=192.168.1.110 NETMASK=255.255.255.0 GATEWAY=192.168.1.1 DNS1=192.168.1.1 DNS2=8.8.8.8
添加下面代码以支持桥接#vim /etc/sysconfig/network NM_BOND_BRIDGE_VLAN_ENABLED=yes
重启网络服务或者重启电脑
[root@centoskvm ~]# service network restart 正在关闭接口 eth0 [确定] 关闭环回接口 [确定] 弹出环回接口 [确定] 弹出界面 eth0 [确定] 弹出界面 br0 [确定]
3:查看桥接情况
[root@centoskvm ~]# brctl show bridge name bridge id STP enabled interfaces br0 8000.000c29b1de85 no eth0 virbr0 8000.000000000000 yes
四 使用图形界面接口创建客户操作系统1005vm
1:开启Applications >> System Tools >> Virtual Machine Manager
界面如下
2点击新建虚拟机如下图鼠标处Create a new virtual machine
3在Name输入框中输入虚拟机的名字1005vm点击Forward按钮如下图显示。
4选择Use ISO image并点击Browse选择ISO镜像所在的路径再选择OS type点击Forward如下图显示
5如上图为虚拟机配置内存和VCPU个数默认是1024MB和1CPUs。点击Forward如下图显示
6:指定虚拟磁盘的空间16.0GB默认是8.0GB,点击Forward如下图显示
7:此时可以选择上图鼠标位置定制别的硬件还可以点击Finish完成创建并启动虚拟机。
配置图如下也可以点击下图鼠标位置进行配置
另外需要注意虚拟机的网络方式配置如下图鼠标所指位置
剩下的就是客户操作系统的安装过程了略如下图
最后配置虚拟机的网络(/etc/sysconfig/network 和 /etc/resolv.conf文件可以不考虑重新配置 )
[root@1005vm ~]# cat /etc/sysconfig/network-scripts/ifcfg-eth0 DEVICE=eth0 BOOTPROTO=static BROADCAST=192.168.77.255 HWADDR=52:54:00:88:F8:03 #mac地址可写可不写因为xml配置文件中已制定了mac地址 IPADDR=192.168.77.93 NETMASK=255.255.255.0 NETWORK=192.168.77.0 NETWORKING_IPV6=no GATEWAY=192.168.77.254 ONBOOT=yes DNS1=210.42.35.35 DNS2=8.8.8.8
[root@1005vm ~]# cat /etc/sysconfig/network NETWORKING=yes HOSTNAME=1003vm NETWORKING_IPV6=no GATEWAY=192.168.77.254
[root@1005vm ~]# cat /etc/resolv.conf # Generated by NetworkManager nameserver 210.42.35.35 nameserver 8.8.8.8
[root@1005vm ~]# service network restart Shutting down interface eth0: Device state: 3 (disconnected) [ OK ] Shutting down loopback interface: [ OK ] Bringing up loopback interface: [ OK ] Bringing up interface eth0: Active connection state: activated Active connection path: /org/freedesktop/NetworkManager/ActiveConnection/1 [ OK ]
[root@1005vm ~]# ping www.baidu.com PING www.a.shifen.com (119.75.217.109) 56(84) bytes of data. 64 bytes from 119.75.217.109: icmp_seq=1 ttl=50 time=39.3 ms 64 bytes from 119.75.217.109: icmp_seq=2 ttl=50 time=33.3 ms 64 bytes from 119.75.217.109: icmp_seq=3 ttl=50 time=36.7 ms --- www.a.shifen.com ping statistics --- 3 packets transmitted, 3 received, 0% packet loss, time 2494ms rtt min/avg/max/mdev = 33.318/36.483/39.370/2.483 ms 五 其余需要注意及说明的情况 1这种方式创建的虚拟机虚拟磁盘的格式为raw此格式不能使用快照功能。 2虚拟机镜像的默认位置在/var/lib/libvirt/images/文件夹下。
3虚拟机的xml配置文件默认在/etc/libvirt/qemu/目录下。
4: 终端下复制虚拟机命令
[root@lw-01 ~]# virt-clone --connect=qemu:///system -o CentOS7.0 -n CentOS7.0-2 -f /opt/CentOS7.0-2.img
-o表示旧的虚拟机名称-n表示新的虚拟机名称-f表示新的虚拟机路径。
待续.......