qemu+kvm 创建虚拟机并虚拟网卡

来源:互联网 发布:人工智能 王者荣耀 编辑:程序博客网 时间:2024/05/22 01:57

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 kvmyum install qemu-kvmln -sv /usr/libexec/qemu-kvm /usr/binmkdir /VMs/c{1,2,3} -pvcp 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网络接口连接至vlan n;
script=file:启动虚拟机时要执行的脚本,默认为/etc/qemu-ifup

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



yum install tigervnc-server
图形化界面执行vncviewer


在出现的登录界面输入提示的登录
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