一、部署环境
使用vmware workstation部署centos7虚拟机,镜像文件:rhel-server-7.2-x86_64-dvd,最小化GUI安装,硬盘100G,内存2G,开启CPU虚拟化。网络模式采用桥接,IP地址:192.168.1.16。
1—— ip 地址跟物理机同网段;
2—— yum源使用阿里云网络源
3—— 开启cpu虚拟化,要在系统关闭的前提下勾选:虚拟化引擎(虚拟化InterVT-x/EPT)
4—— 关闭防火墙/selinux
5——需要另外安装图形界面,为后续kvm图形化准备


1)安装虚拟机后,配置网络(跟物理机一样的网关,保证虚拟机可以连接外网)

]# cat /etc/sysconfig/network-scripts/ifcfg-eno16777736
 TYPE=Ethernet
 BOOTPROTO=static
 DEVICE=eno16777736
 ONBOOT=yes
 IPADDR=192.168.1.16
 NETMASK=255.255.255.0
 GATEWAY=192.168.1.1
 DNS1=101.198.199.200
 DNS2=101.198.198.198
 2)配置yum网络源
 ]# cat /etc/yum.repos.d/ali.repo
 [aliyun]
 name=aliyun_yum
 baseurl=http://mirrors.aliyun.com/centos/7/os/x86_64/
 enabled=1
 gpgcheck=0
 ]# yum repolist
 repolist: 10,019
 3) 安装图形界面
 yum grouplist | more
 yum groupinstall "GNOME Desktop " -y
 #yum install nautilus-open-terminal
 4) 关闭防火墙和selinux
 sed -i ‘s/SELINUX=enforcing/SELINUX=disabled/’ /etc/sysconfig/selinux
 systemctl disable firewalld
 systemctl stop firewalld

二、安装kvm
2.1 验证cpu 是否支持kvm

#egrep ‘(vmx|svm)’ /proc/cpuinfo


有vmx(Intel)或svm(AMD)字样,就说明CPU的支持的。
2.2 最小化安装依赖包

#yum install epel-release net-tools vim unzip zip wget ftp -y


2.3安装kvm相关的包

#yum install qemu-kvm libvirt virt-install bridge-utils -y
 ]# yum install kvm kmod-kvm qemu kvm-qemu-img virt-viewer


2.4 验证安装结果

#lsmod | grep kvm
 kvm_intel 183621 0
 kvm 586948 1 kvm_intel
 irqbypass 13503 1 kvm


使用命令检查kvm是否成功安装

[root@localhost ~]#virsh -c qemu:///system list


2.5 安装图形客户端
2.5.1 安装兼容组信息

#yum groups mark convert
 #yum groups list hidden | grep -i virt //查看软件组
 #yum -y groups install “Virtualization Host” “Virtualization Client” “Virtualization Platform” //安装KVM

软件组
启动KVM服务:

systemctl restart libvirtd
 systemctl enable libvirtd


确认服务运行:systemctl status libvirtd


三、部署kvm虚拟机
3.1 格式化独立磁盘
添加一块50G磁盘,将独立磁盘分区,格式化为XFS格式,系统中创建挂载点,使得系统可以使用该空间。

#mkdir /vdir
 #mount /dev/sdb /vdir
 ]# mkfs -t xfs /dev/sdb
 ]# mount /dev/sdb /vdir/
 ]# df -Th
 /dev/sdb xfs 50G 33M 50G 1% /vdir

3.2 安装KVM相关环境包

#yum install qemu-kvm qemu-kvm-tools virt-manager libvirt virt-install -y
 ——qemu-kvm 虚拟化软件
 ——virsh virt-manager virt-viewer virt-install other-tools是libvirt用户态的工具

3.3 将安装的镜像放入本地/opt

镜像:CentOS-7-x86_64-Minimal-1810.iso
 #cd /opt
 ]# ls
 CentOS-7-x86_64-Minimal-1810.iso

3.4 查看KVM服务启动状态、执行虚拟机安装

]# systemctl status libvirtd.service
 ]# virt-install --help (可以安装man中文包)


3.5 创建虚拟机的域空间

#cd /vdir //注:此处文需要创建到专门供虚拟机使用的挂载目录下。
 #qemu-img create -f qcow2 ct01.img 10G
 virt-install --name ct01 \ //指定虚拟机名称
 –virt-type kvm \ //指定安装类型
 –ram 1024 \ //指定虚拟机内存
 –cdrom=/opt/CentOS-7-x86_64-Minimal-1810.iso \ //系统镜像在本地位置
 –disk path=/vdir/ct01.img,size=10 \
 –network network=default 
 –graphics vnc,listen=0.0.0.0 \ //远程访问,任何主机都可以
 –noautoconsole //禁止自动连接至虚拟机的控制台
 开始安装…
 域安装仍在进行。您可以重新连接
 到控制台以便完成安装进程。

另一个命令行创建虚拟机的方法:

virsh-install 
 –connect qemu:///system --virt-type kvm 
 –name demo --memory 2048 --cpu host --vcpus 1 --os-variant centos7.0 
 –network bridge=vbr0
 –disk path=/var/lib/libvirt/images/demo.qcow2,bus=scsi 
 –boot menu=on ,useserial=on --nograhics --pxe
 这里要准备一个demo.xml文件,以及bridge的配置

四、利用VNC远程连接
TigerVNC 下载地址:http://download.canadiancontent.net/TigerVNC.html
安装在windows物理主机上。打开——开始——TigerVNC——TigerVNC Viewer ——输入虚拟机ip 192.168.1.16,进入安装虚拟机状态。
查看虚拟机:

]# virsh list --all
 ]# virsh start CentOS-7-x86_64
 打开虚拟机,用TigerVNC Viewer 连接工具,修改新的虚拟机的ip
 Centos#ip ad
 Centos#vi /etc/sysconfig/network-scripts/ifcfg-eth0
 添加ip地址 IPADDR=192.168.1.10
 修改ONBOOT=yes
 修改BOOTPROTO=static
 #systemctl restart network


此时新的虚拟机还不能连接上宿主机,需要进行网卡配置,将KVM虚拟机中的网卡改为桥接模式,让局域网的其他用户可以正常访问)


让虚拟机跟宿主机ping通的方法一:
这里穿插一个知识点,就是添加物理机的虚拟网卡vbr

#virsh net-list ##查看虚拟网卡
 #cd /etc/libvt/qemu/networs
 #curl http://118.144.89.240/vbr.xml -O ##下载vbr.xml模板
 #vim vbr.xml

 vbr


 ###注意,不要跟eth0的网段一样,否则失败

#virsh net-define vbr.xml
 #virsh net-start vbr
 #systemctl restart network

刚刚新建的虚拟机的网卡可以选择vbr 网卡,然后ip 设置在192.168.2.0/32网段。同时宿主机 添加一块网卡,网路连接选择NAT模式,新建ifcf-eth1内容,ip设置为192.168.2.0/32网段,这样就可以跟新建的虚拟机ping了。


让虚拟机跟宿主机ping通的方法二:
宿主机]# brctl show ##查看已有网桥
]# vim br0.sh
创建一个脚本,删除ens33网卡的ip信息,新建一个桥接网卡,并且将ens33网卡的ip信息转移到新建的桥接网卡

宿主机# vim br0.sh
 #!/bin/bash
 brctl addbr br0 #创建一个桥接网卡br0
 brctl addif br0 ens33 #将ens33网卡的桥接信息转到br0网卡
 ip addr del dev ens33 192.168.1.14/24 #将ens33网卡的ip信息删除
 ifconfig br0 192.168.1.14/24 up #将ens33网卡的ip信息这只到br0网卡上
 route add default gw 10.0.0.2 #添加网关
 使用ifocnfig查看网卡的ip信息,可以看到br0的地址已经变为了192.168.1.14/24
 ]# ifconfig
 使用命令修改KVM虚拟机的信息:
 ]# virsh edit CentOS-7-x86_64


69 修改为:
##桥接
71 修改为:

修改完成后关闭虚拟机,启动虚拟机:

]# virsh shutdown CentOS-7-x86_64
 ]# virsh start CentOS-7-x86_64
 宿主机#ping 192.168.1.10
 #ssh 192.168.1.10

virt-install命令有许多选项,这些选项大体可分为下面几大类,同时对每类中的常用选项也做出简单说明。
◇ 一般选项:指定虚拟机的名称、内存大小、VCPU个数及特性等;
-n NAME, --name=NAME:虚拟机名称,需全局惟一;
-r MEMORY, --ram=MEMORY:虚拟机内在大小,单位为MB;
–vcpus=VCPUS[,maxvcpus=MAX][,sockets=#][,cores=#][,threads=#]:VCPU个数及相关配置;
–cpu=CPU:CPU模式及特性,如coreduo等;可以使用qemu-kvm -cpu ?来获取支持的CPU模式;
◇ 安装方法:指定安装方法、GuestOS类型等;
-c CDROM, --cdrom=CDROM:光盘安装介质;
-l LOCATION, --location=LOCATION:安装源URL,支持FTP、HTTP及NFS等,如ftp://172.16.0.1/pub;
–pxe:基于PXE完成安装;
–livecd: 把光盘当作LiveCD;
–os-type=DISTRO_TYPE:操作系统类型,如linux、unix或windows等;
–os-variant=DISTRO_VARIANT:某类型操作系统的变体,如rhel5、fedora8等;
-x EXTRA, --extra-args=EXTRA:根据–location指定的方式安装GuestOS时,用于传递给内核的额外选项,例如指定kickstart文件的位置,–extra-args “ks=http://172.16.0.1/class.cfg”
–boot=BOOTOPTS:指定安装过程完成后的配置选项,如指定引导设备次序、使用指定的而非安装的kernel/initrd来引导系统启动等 ;例如:
–boot cdrom,hd,network:指定引导次序;
–boot kernel=KERNEL,initrd=INITRD,kernel_args=”console=/dev/ttyS0”:指定启动系统的内核及initrd文件;
◇ 存储配置:指定存储类型、位置及属性等;
–disk=DISKOPTS:指定存储设备及其属性;格式为–disk /some/storage/path,opt1=val1,opt2=val2等;常用的选项有:
device:设备类型,如cdrom、disk或floppy等,默认为disk;
bus:磁盘总结类型,其值可以为ide、scsi、usb、virtio或xen;
perms:访问权限,如rw、ro或sh(共享的可读写),默认为rw;
size:新建磁盘映像的大小,单位为GB;
cache:缓存模型,其值有none、writethrouth(缓存读)及writeback(缓存读写);
format:磁盘映像格式,如raw、qcow2、vmdk等;
sparse:磁盘映像使用稀疏格式,即不立即分配指定大小的空间;
–nodisks:不使用本地磁盘,在LiveCD模式中常用;
◇ 网络配置:指定网络接口的网络类型及接口属性如MAC地址、驱动模式等;
-w NETWORK, --network=NETWORK,opt1=val1,opt2=val2:将虚拟机连入宿主机的网络中,其中NETWORK可以为:
bridge=BRIDGE:连接至名为“BRIDEG”的桥设备;
network=NAME:连接至名为“NAME”的网络;
其它常用的选项还有:
model:GuestOS中看到的网络设备型号,如e1000、rtl8139或virtio等;
mac:固定的MAC地址;省略此选项时将使用随机地址,但无论何种方式,对于KVM来说,其前三段必须为52:54:00;
–nonetworks:虚拟机不使用网络功能;
◇ 图形配置:定义虚拟机显示功能相关的配置,如VNC相关配置;
–graphics TYPE,opt1=val1,opt2=val2:指定图形显示相关的配置,此选项不会配置任何显示硬件(如显卡),而是仅指定虚拟机启动后对其进行访问的接口;
TYPE:指定显示类型,可以为vnc、sdl、spice或none等,默认为vnc;
port:TYPE为vnc或spice时其监听的端口;
listen:TYPE为vnc或spice时所监听的IP地址,默认为127.0.0.1,可以通过修改/etc/libvirt/qemu.conf定义新的默认值;
password:TYPE为vnc或spice时,为远程访问监听的服务进指定认证密码;
–noautoconsole:禁止自动连接至虚拟机的控制台;
◇ 设备选项:指定文本控制台、声音设备、串行接口、并行接口、显示接口等;
–serial=CHAROPTS:附加一个串行设备至当前虚拟机,根据设备类型的不同,可以使用不同的选项,格式为“–serial type,opt1=val1,opt2=val2,…”,例如:
–serial pty:创建伪终端;
–serial dev,path=HOSTPATH:附加主机设备至此虚拟机;
–video=VIDEO:指定显卡设备模型,可用取值为cirrus、vga、qxl或vmvga;
◇ 虚拟化平台:虚拟化模型(hvm或paravirt)、模拟的CPU平台类型、模拟的主机类型、hypervisor类型(如kvm、xen或qemu等)以及当前虚拟机的UUID等;
-v, --hvm:当物理机同时支持完全虚拟化和半虚拟化时,指定使用完全虚拟化;
-p, --paravirt:指定使用半虚拟化;
–virt-type:使用的hypervisor,如kvm、qemu、xen等;所有可用值可以使用’virsh capabilities’命令获取;
◇ 其它:
–autostart:指定虚拟机是否在物理启动后自动启动;
–print-xml:如果虚拟机不需要安装过程(–import、–boot),则显示生成的XML而不是创建此虚拟机;默认情况下,此选项仍会创建磁盘映像;
–force:禁止命令进入交互式模式,如果有需要回答yes或no选项,则自动回答为yes;
–dry-run:执行创建虚拟机的整个过程,但不真正创建虚拟机、改变主机上的设备配置信息及将其创建的需求通知给libvirt;
-d, --debug:显示debug信息;

尽管virt-install命令有着类似上述的众多选项,但实际使用中,其必须提供的选项仅包括–name、–ram、–disk(也可是–nodisks)及安装过程相关的选项。此外,有时还需要使用括–connect=CONNCT选项来指定连接至一个非默认的hypervisor。