一,什么是KVM
KVM包括很多部件:首先,它是一个Linux内核模块(现在包括在主线中)用于转换处理器到一种新的用户 (guset) 模式。用户模式有自己的ring状态集合,但是特权ring0的指令会陷入到管理器(hypervisor)的代码。由于这是一个新的处理器执行模型,代码不需要任何的改动。
除了处理器状态转换,这个内核模块同样处理很小一部分低层次的模拟,比如MMU注册(用于管理VM)和一部分PCI模拟的硬件。
在可预见的未来,Qemu团队专注于硬件模拟和可移植性,同时KVM团队专注于内核模块(如果某些部分确实有性能提升的话,KVM会将一小部分模拟代码移进来)和与剩下的用户空间代码的交互。
kvm-qemu可执行程序像普通Qemu一样:分配RAM,加载代码,不同于重新编译或者调用calling KQemu,它创建了一个线程(这个很重要);这个线程调用KVM内核模块去切换到用户模式,并且去执行VM代码。当遇到一个特权指令,它从新切换会KVM内核模块,该内核模块在需要的时候,像Qemu线程发信号去处理大部分的硬件仿真。
这个体系结构一个比较巧妙的一个地方就是客户代码被模拟在一个posix线程,这允许你使用通常Linux工具管理。如果你需要一个有2或者4核的虚拟机,kvm-qemu创建2或者4个线程,每个线程调用KVM内核模块并开始执行。并发性(若果你有足够多的真实核)或者调度(如果你不管)是被通用的Linux调度器,这个使得KVM代码量十分的小
当一起工作的时候,KVM管理CPU和MEM的访问,QEMU仿真硬件资源(硬盘,声卡,USB,等等)当QEMU单独运行时,QEMU同时模拟CPU和硬件。
二,安装配置KVM
- # yum -y install kvm python-virtinst libvirt bridge-utils \
- virt-manager qemu-kvm-tools virt-viewer virt-v2v qemu-kvm tunctl
- [root@localhost ~]#vim /etc/sysconfig/selinux //关闭selinux
- SELINUX=disabled
- [root@localhost ~]#reboot
- [root@localhost ~]# cat /etc/redhat-release
- CentOS release 6.5 (Final) //centos 6.5
三,启动libvirtd
- [root@localhost ~]# /etc/init.d/libvirtd start //启动
- [root@localhost ~]# ps -e|grep libvirtd //查看是否启动
- 19458 ? 00:00:01 libvirtd
四,查看kvm模块是否正确加载
- [root@localhost ~]# lsmod |grep kvm
- kvm_intel 54285 0
- kvm 333172 1 kvm_intel
五,配置网络桥接
- [root@localhost network-scripts]# cat ifcfg-eth0 |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}'
- DEVICE=eth0
- TYPE=Ethernet
- ONBOOT=yes
- BOOTPROTO=none
- BRIDGE=br0
- IPV6INIT=no
- HWADDR=F8:BC:12:60:99:86
- [root@localhost network-scripts]# cat ifcfg-br0 |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}'
- DEVICE=br0
- TYPE=Bridge
- ONBOOT=yes
- BOOTPROTO=static
- IPADDR=192.168.10.103
- GATEWAY=192.168.10.1
- NETMASK=255.255.255.0
- DNS1=192.168.10.1
- IPV6INIT=no
- DELAY=0
重启网络,发现报以下错误:
- [root@localhost network-scripts]# /etc/init.d/network start
- 弹出环回接口: [确定]
- 弹出界面 eth0: 错误:激活连接失败:Master connection not found or invalid
- [失败]
- 弹出界面 br0: 错误:激活连接失败:Failed to determine connection's virtual interface name
- [失败]
- RTNETLINK answers: File exists
- RTNETLINK answers: File exists
- RTNETLINK answers: File exists
解决办法:
- [root@localhost rules.d]# service NetworkManager stop //这个关闭掉就行
- 停止 NetworkManager 守护进程: [确定]
- [root@localhost rules.d]# service network restart
- 正在关闭接口 br0: [确定]
- 正在关闭接口 eth0: [确定]
- 关闭环回接口: [确定]
- 弹出环回接口: [确定]
- 弹出界面 eth0: [确定]
- 弹出界面 br0: Determining if ip address 192.168.10.103 is already in use for device br0...
- [确定]
如果以下内容就说明配置成功了:
- [root@localhost network-scripts]# ifconfig
- br0 Link encap:Ethernet HWaddr F8:BC:12:60:99:86 //有这个就OK
- inet addr:192.168.10.103 Bcast:192.168.10.255 Mask:255.255.255.0
- inet6 addr: fe80::fabc:12ff:fe60:9986/64 Scope:Link
- UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
- RX packets:36416 errors:0 dropped:0 overruns:0 frame:0
- TX packets:28648 errors:0 dropped:0 overruns:0 carrier:0
- collisions:0 txqueuelen:0
- RX bytes:13151508 (12.5 MiB) TX bytes:5962449 (5.6 MiB)
- eth0 Link encap:Ethernet HWaddr F8:BC:12:60:99:86
- inet6 addr: fe80::fabc:12ff:fe60:9986/64 Scope:Link
- UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
- RX packets:1360857 errors:0 dropped:0 overruns:0 frame:0
- TX packets:902173 errors:0 dropped:0 overruns:0 carrier:0
- collisions:0 txqueuelen:1000
- RX bytes:1913592871 (1.7 GiB) TX bytes:72387220 (69.0 MiB)
- lo Link encap:Local Loopback
- inet addr:127.0.0.1 Mask:255.0.0.0
- inet6 addr: ::1/128 Scope:Host
- UP LOOPBACK RUNNING MTU:16436 Metric:1
- RX packets:176842 errors:0 dropped:0 overruns:0 frame:0
- TX packets:176842 errors:0 dropped:0 overruns:0 carrier:0
- collisions:0 txqueuelen:0
- RX bytes:880282316 (839.5 MiB) TX bytes:880282316 (839.5 MiB)
- virbr0 Link encap:Ethernet HWaddr 52:54:00:1A:B6:F1
- inet addr:192.168.122.1 Bcast:192.168.122.255 Mask:255.255.255.0
- UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
- RX packets:0 errors:0 dropped:0 overruns:0 frame:0
- TX packets:37 errors:0 dropped:0 overruns:0 carrier:0
- collisions:0 txqueuelen:0
- RX bytes:0 (0.0 b) TX bytes:4651 (4.5 KiB)
- [root@localhost network-scripts]# brctl show
- bridge name bridge id STP enabled interfaces
- br0 8000.f8bc12609986 no eth0 //有这个就OK
- virbr0 8000.5254001ab6f1 yes virbr0-nic
六,用virt-install生成.img文件
- # virt-install --name=ubuntu1 \
- --ram 1024 --vcpus=1 \
- --disk path=/root/ubuntu1.img,size=10 \
- --accelerate --cdrom /root/ubuntu-14.04-desktop-amd64.iso \
- --graphics vnc,port=5920 --network bridge=br0
如果报以下错误:
- could not open disk image : Permission denied
解决方法:
- [root@localhost ~]# cat /etc/libvirt/qemu.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}'
- vnc_listen = "0.0.0.0"
- user = "root" //去掉注释
- group = "root" //去掉注释
- dynamic_ownership = 0 //去掉注释,把1改为0
这一步做完,系统文件就好了。
七,启动虚拟机
如果报以下错误
- [root@localhost ~]# virsh start ubuntu1
- 错误:域已经活跃
解决办法:
- [root@localhost ~]# pkill qemu-kvm
- [root@localhost ~]# virsh start ubuntu1
- 域 ubuntu1 已开始
- [root@localhost ~]# virt-viewer ubuntu1 //进入图形界面
看一下成果
转载请注明
作者:海底苍鹰
地址:http://blog.51yip.com/cloud/1627.html
为什么进行网络桥接配置后主机就不能上网了
为什么进行网络桥接配置后,主机无法上网