kvm+qemu虚拟主机

Linux目前流行的开源虚拟化技术解决方案:
主机虚拟化:xen, kvm, virtualbox
容器级:lxc, libcontainer, runC, openvz
模拟器:qemu

KVM模块load进内存之后,系统的运行模式:
内核模式:GuestOS执行IO类的操作时,或其它的特殊指令操作时的模式;它也被称为“Guest-Kernel”模式;
用户模式:Host OS的用户空间,用于代为GuestOS发出IO请求;
来宾模式:GuestOS的用户模式;所有的非IO类请求;

Qemu:
处理器模拟器
仿真各种IO设备
将仿真设备连接至主机的物理设备
提供用户接口
qemu-kvm 可以完成虚拟机创建,安装,启动运行
qemu-img 辅助对磁盘镜像的管理
qemu-IO 对IO使用情况管理

运行中的一个kvm虚拟机就是一个qemu-kvm进程,运行qemu-kvm程序并传递给它合适的选项及参数即能完成虚拟机启动,终止此进程即能关闭虚拟机;


安装使用KVM:
判断CPU是否支持硬件虚拟化:
grep -i -E ‘(vmx|svm|lm)’ /proc/cpuinfo

modprobe kvm
yum install qemu-kvm
ln -sv /usr/libexec/qemu-kvm /usr/bin
mkdir /VMs/c{1,2,3} -pv
cp cirros-no_cloud-i386.img /VMs/c1/        ## cirros 是一个微型镜像文件 用来测试

brctl addbr br-and ##创建虚拟网桥
ip link set br-and up ##启动网桥

编写启动虚拟机时要执行的脚本,默认为/etc/qemu-ifup

vim /etc/qemu-ifup
 #!/bin/bash
      bridge=br0
  if  [ -n "$1" ];then
      ip link set $1 up
      sleep 1
      brctl addif $bridge $1
      [ $? -eq 0 ] && exit 0 || exit 1
  else
      echo "Error: no interface specified."
  exit 2
  fi    

 chmod +x /etc/qemu-ifup

创建虚拟机并虚拟网卡网桥

qemu-kvm -smp 1 -m 32 -name c2 -drive file=/data/img/c1.img,if=virtio,media=disk,format=qcow2 -vnc :1 -net nic,
model=e1000,macaddr=52:54:00:00:00:01 -net tap,script=/etc/qemu-ifup -daemonize


#######
    -smp n[,maxcpus=cpus][,cores=cores][,threads=threads][,sockets=sockets]:指明虚拟机上vcpu的数量及拓扑;
    -name NAME:当前虚拟机的名称,要惟一;
    -drive [file=file][,if=type][,media=d][,index=i] [,cache=writethrough|writeback|none|directsync|unsafe][,format=f]:
        file=/PATH/TO/SOME_IMAGE_FILE:映像文件路径;
        if=TYPE:块设备总线类型,ide, scsi, sd, floppy, virtio,
        media=TYPE:介质类型,cdrom和disk;
        format=f:磁盘映像文件的格式;
    -net nic[,vlan=n][,macaddr=mac][,model=type][,name=str][,addr=str][,vectors=v] 为虚拟机创建一个网络接口,并将其添加至指定的VLAN;
    -net nic,model=? model=type:指明模拟出的网卡的型号,ne2k_pci,i82551,i82557b,i82559er,rtl8139,e1000,pcnet,virtio;
        macaddr=mac:指明mac地址;52:54:00: 
    -net tap[,vlan=n][,name=str][,fd=h][,fds=x:y:...:z][,ifname=name][,script=file][,downscript=dfile]:通过物理的TAP网络接口连接至vlann;
        script=file:启动虚拟机时要执行的脚本,默认为/etc/qemu-ifup

#########
    -vnc :1 通过vncserver终端1 链接可以在图形化界面登录

yum install tigervnc-server
图形化界面执行vncviewer
kvm+qemu虚拟主机_第1张图片

在出现的登录界面输入提示的登录
user:cirros
password:cubswin:)

让虚拟机通信

为创建的虚拟主机添加ip地址 内网地址 可随意创建
ifconfig add eth0 10.1.0.1/16

虚拟主机可以和网桥通信,在宿主机上执行

ip addr add 10.1.0.222/16 br-and ##给虚拟网桥添加地址
echo 1 > /proc/sys/net/ipv4/ip_forward ## 开启路由转发

让虚拟主机可以和宿主机仅主机通信

iptables -t nat -A POSTROUTING -s 10.1.0.0/16 -j SNAT --to-source 172.16.250.200

让虚拟主机可以被访问到

iptables -t nat -A PREROUTING -d 172.16.250.200 -p tcp --dport 22022 -j DNAT --to-destination 10.1.0.1:22

你可能感兴趣的:(virtualbox,kvm,xen,虚拟化技术,解决方案,kvm+qemu)