KVM定制OpenStack云主机
如何定制化OpenStack云主机?从去年10月份刚开始接触OpenStack,到现在也有一年了。虽说目前只是停留在用它,对它的一些组件简单的了解,但谈到制作出一个OpenStack云主机的镜像还真不会。今年年初因为一个比赛需要给云主机安装tomcat、ssh等服务,一头雾水,网上查资料。也有正确的资料,但对于我来说似乎也不管用。记得当时是用libvirt的virsh来实现的。而且云主机用的是网上下载的ubuntu14.04的server版本,而且又看到网上说,OpenStack只能支持server版本的,我把只支持server当理论来记在脑海里,现在想想真是傻的不行。
前面唠嗑了下,下面我会一步步来讲解如何利用KVM来创建虚拟机(即本文提到的云主机)。本文使用的环境是ubuntu14.04。一些KVM的概念这里就不阐述了,网上资料很多很全。
一、ubuntu14.04中安装tun模块。参考上篇博客,这里不再展开。博客地址
http://www.cnblogs.com/grglym/p/7891253.html
为什么用安装tun模块呢?既然需要对虚拟机进行定制化,即需要安装一些个性化服务,文章开头中有提及的,如tomcat、ssh等等。安装这些就需要网络进行安装,这样更加方便。所以呢,虚拟机需要能够上网呀!在KVM的网络实现中是通过qemu来实现。qemu网络相关的教程很多,可以参考如下链接:
http://www.jianshu.com/p/110b60c14a8b http://blog.csdn.net/ztsinghua/article/details/49741795
这两个链接把qemu的网络细节说的很清楚。本文选择就是qemu的桥接网络方式来实现KVM虚拟机连接Internet。
二、开启CPU虚拟化服务。(vmware和virtualbox各自的虚拟化服务如何开启可网上查看)
modprobe kvm
cat /proc/cpuinfo |grep vmx
在宿主机中输入如上指令,在flags一栏中查看是否有“vmx”或者“svm”字眼,如图1所示:
图 1
说明CPU是Inter的,如果是AMD的CPU,应该是“svm”。
我所遇到的错误:
modprobe: ERROR: could not insert 'kvm_intel': Operation not supported
通过在宿主机输入如下指令
dmesg | grep kvm
输出为:
kvm: no hardware support
解决办法:看下是否开启CPU虚拟化,如果你是用VMware或者virtualbox,它们有各自的CPU虚拟化选项,勾上即可。如果是在物理机上,则需要进入bios了。
三、安装kvm-qemu工具
kvm-qemu这是个什么鬼呢?我们应该知道KVM是在linux内核内,KVM自身功能也非常。。。。不夸它了,反正就是很有用的虚拟化工具。但它也有痛点,即实现不了网卡虚拟化等一些必要功能,所以需要借助qemu来实现。kvm-qemu是kvm在用户态下的一个管理工具吧!接下来源码安装kvm-qemu。
1、源码下载
http://sourceforge.net/projects/kvm/files/
下载个最新版本qemu-kvm-1.2.0.tar.gz
tar -zxvf qemu-kvm-1.2.0.tar.gz
cd qemu-kvm-1.2.0
2、对qemu-kvm打补丁。
因为本文用的环境时ubuntu14.04,所以需要对qemu-kvm-1.2.0中的configure进行简单修改,不然会报错。如图2所示,添加黑框中的代码,分别为:
timer_create(CLOCK_REALTIME, NULL, NULL);
$pthread_lib
libs_qga="-lrt $libs_qga"
图 2
需要修改的代码在2681行左右,可通过vim的命令模式下输入/<time.h>,来快速定位需要修改的代码位置。
3、qemu-kvm编译及安装
./configure --prefix=/usr/local/kvm (注,如果报错,需要查看第2步中代码是否修改正确)
make
make install
四、加载KVM内核模块
modprobe kvm-intel
lsmod | grep kvm
图 3
如果modprobe出错,可查看二的开启CPU虚拟化服务。
五、创建br0网桥
1、安装libvirt
apt-get install libvirt-bin
2、创建br0网桥
virsh iface-bridge eth0 br0
brctl show
图 4
图 5
六、KVM创建虚拟机
经过以上五大步骤,终于把准备工作做好了,接下来的才是重头菜。
1、KVM创建虚拟磁盘,磁盘格式为qcow2。kvm的一些指令可以从网上查到,这里不再解释。
/usr/local/kvm/bin/qemu-img create -f qcow2 openstack.img 10G
2、KVM虚拟机开启和关闭的网络脚本配置。
开启脚本 qemu-ifup.sh:
#!/bin/bash
switch=br0
if [ -n "$1" ]; then
#create a tap interface
#tunctl -u $(whoami) -t $1
#start up the tap interface
ip link set $1 up
sleep 1
#add tap interface to the bridge
brctl addif ${switch} $1
exit 0
else
echo "error: no interface specified"
exit 1
fi
关闭脚本 qemu-ifdown.sh :
#!/bin/bash
switch=br0
if [ -n "$1" ]; then
#delete the specified interface
tunctl -d $1
#rlease tap interface from bridge
brctl delif $(switch) $1
#shutdown the tap interface
ip link set $1 down
exit 0
else
echo "error: no interface specified"
exit 1
fi
脚本授权:
chmod +x qemu-ifup.sh
chmod +x qemu-ifdown.sh
3、KVM启动虚拟机安装:
/usr/local/kvm/bin/qemu-system-x86_64 -hda openstack.img -cdrom ubuntu-14.04.5-desktop-amd64.iso -boot d -m 1024 -net nic -net tap,ifname=tap1,script=qemu-ifup.sh,downscript=no
4、安装完成后,下次如需重新进入系统,可用如下命令:
/usr/local/kvm/bin/qemu-system-x86_64 -hda openstack.img -boot d -m 1024 -net nic -net tap,ifname=tap1,script=qemu-ifup.sh,downscript=no
5、KVM虚拟机运行结果展示如图6所示:
图 6
6、KVM虚拟机访问Internet效果展示如图7所示:
图 7
七、总结
利用KVM的整个过程还是有些麻烦,以后会尝试用KVM的管理工具libvirt来实现更加便捷的定制化云主机。网上资料会有很多,可能不同的环境需要参考不同的资料,这个过程需要踩过很多个坑,这里记录下在本文环境中可行的处理步骤。
八、参考链接
http://blog.csdn.net/ztsinghua/article/details/49741795
http://royluo.org/2014/06/15/kvm-install-1/
http://blog.csdn.net/zhaihaifei/article/details/23168621