kvm

安装

安装linux服务器,以centos7 为例

开启虚拟化

如果裸机在bios里面开启
如果是虚拟机,在虚拟机里面开启,参考下图

如果是虚拟机的话,需要开启嵌套虚拟化,参考链接https://blog.csdn.net/qq_44839276/article/details/121496045

# 检查宿主机的kvm_intel模块是否支持及开启了嵌套虚拟机功能 
modinfo kvm_intel | grep nested
parm: nested:bool

cat /sys/module/kvm_intel/parameters/nested
N

# 如果不是Y的话,执行下面语句,需要先将虚拟机关闭,不然设置的时候会报错
modprobe -r kvm-intel
modprobe kvm-intel nested=1
cat /sys/module/kvm_intel/parameters/nested
Y

安装虚拟化软件包

yum -y install libvirt* virt-* qemu-kvm*

启动libvirtd

systemctl start libvirtd.service
systemctl enable libvirtd.service

ok 后创建虚拟机

virt-install --virt-type kvm --os-type linux --os-variant rhel7 --name centos7 --memory 1024 --vcpus 1 --disk /opt/centos2.raw,format=raw,size=10 --cdrom /var/lib/libvirt/images/CentOS-7-x86_64-Minimal-2009.iso  --network network=br0 --graphics vnc,listen=0.0.0.0 --noautoconsole

# 注iso文件,不能放在root 目录下,否则会有权限相关问题报错。

# 下面是windows 上面实验的
 virt-install --virt-type kvm  --name windows --memory=2048 --vcpus=2 --disk /opt/windows.qcow2,format=qcow2,size=30 --cdrom /var/lib/libvirt/images/cn_windows_server_2012_r2_x64_dvd_2707961.iso   --graphics vnc,listen=0.0.0.0,port=5910  --noautoconsole

参数参考 
一、virt-install是一个命令行工具,它能够为KVM、Xen或其它支持libvrit API的hypervisor创建虚拟机并完成GuestOS安装;此外,它能够基于串行控制台、VNC或SDL支持文本或图形安装界面。安装过程可以使用本地的安装介质如CDROM,也可以通过网络方式如NFS、HTTP或FTP服务实现。对于通过网络安装的方式,virt-install可以自动加载必要的文件以启动安装过程而无须额外提供引导工具。当然,virt-install也支持PXE方式的安装过程,也能够直接使用现有的磁盘映像直接启动安装过程。

 

二、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。  

通过tightvnc 连接 ,默认端口为5900

下载链接:https://www.tightvnc.com/

通过vnc连接后即可以安装系统

安装成功后,重启登陆。更改grub 实现kvm console登陆

grubby --update-kernel=ALL --args="console=ttyS0,115200n8"
后重启 

通过裸机的virsh console 命令即可以登陆

virsh 常用命令

virsh list #只显示开机状态的
virsh list --all #显示所有 
virsh start centos7 #启动虚机
virsh shutdown centos6 # 关闭虚机 
virsh destory centos7 #强制关闭虚机
virsh undefine centos7 # 删除
virsh define centos7.xml # 导入虚机

virsh edit centos7 # 修改配置文件 
virsh domrename aaaaaaa --new-name lifeicentos   # 修改虚机名称 
virsh suspend centos7 #挂起虚机 
virsh suspend web01 # 恢复虚机
virsh vncdisplay web01 # 查看端口号
virsh autostart web01 # 开机启动 
virsh autostart --disable web01 # 取消开机启动 

virsh edit centos7 # 编缉配置文件 


virsh attach-disk centos7 /opt/centos7-add01.qcow2 vdb --live --cache=none --subdriver=qcow2   # 添加硬盘

virsh detach-disk centos7 vdb #卸载 



kvm 虚拟机虚拟磁盘格式转换及快照

# 格式 
raw: 裸格式,占用空间大,不支持快照,读写性能好
qcow2,占用空间小,支持快照,读写性能比raw差一点

# qemu-img 命令
kvm 虚拟机的碰盘文件,都是通过qemu-img 创建的 
qemu-img info centos.raw
qemu-img create  # 创建
qemu-img resize  
qemu-img convert  格式转换

qemu-img convert -f raw -O qcow2 centos7.raw centos7.qcow2 

qemu-img resize /opt/centos7-add01.qcow2 +5G #扩容 

snapshot

virsh snapshot-create centos7   #创建
virsh snapshot-list centos7   #列出
virsh snapshot-revert centos7 --snapshotname 1516574134  #还原
virsh snapshot-delete centos7 --snapshotname  1516574100 #删除 

注:
1.如果创建快照的时候没有指定快照的名称,默认kvm会以unix时间戳作为快照名称 。
2.如果虚拟机使用的raw的虚拟机磁盘格式,它在创建快照的时候会报错。

虚机克隆

virt-clone --auto-clone -o web01 

桥接网络创建

virsh iface-bridge eth0 br0   

[root@BJ-Zabbix-Proxy ~]# cat /etc/sysconfig/network-scripts/ifcfg-br_em3
TYPE=Bridge
BOOTPROTO=none
DEFROUTE=yes
PEERDNS=yes
PEERROUTES=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_PEERDNS=yes
IPV6_PEERROUTES=yes
IPV6_FAILURE_FATAL=no
NAME=br_em3
DEVICE=br_em3
ONBOOT=yes
BRIDGING_OPTS=priority=32768
[root@BJ-Zabbix-Proxy ~]# cat /etc/sysconfig/network-scripts/ifcfg-em3
TYPE=Ethernet
BOOTPROTO=none
DEVICE=em3
ONBOOT=yes
BRIDGE=br_em3


# 创建虚拟nat网卡文件
echo "<network><name>nat_network</name><forward mode='nat'/><bridge name='virbr1'/><ip address='192.168.123.1' netmask='255.255.255.0'><dhcp><range start='192.168.123.2' end='192.168.123.254'/></dhcp></ip></network>" > nat_network.xml

# 下面是创建桥接的网卡文件 
cat bridge_network.xml 

<interface type='bridge'>
  <mac address='52:54:00:6b:29:7e'/>
  <source bridge='br0'/>
  <model type='virtio'/>
  <address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/>
</interface>

# 创建网卡,并启动
virsh net-define nat_network.xml
virsh net-start nat_network
virsh net-autostart nat_network

# 添加
virsh attach-interface centos7 --type bridge --source br-em3 --model virtio --config --live

# 查看网卡
virsh domiflist centos7
# 删除虚拟网卡 
virsh detach-interface centos7 --type network --mac  52:54:00:a6:b9:de --config --live
# 查看虚拟网卡对应的配置参数
[root@BJ-Zabbix-Proxy ~]# virsh net-dumpxml nat_network
<network connections='1'>
  <name>nat_network</name>
  <uuid>6b9d7fbf-7091-41b8-b859-810d171363e0</uuid>
  <forward mode='nat'>
    <nat>
      <port start='1024' end='65535'/>
    </nat>
  </forward>
  <bridge name='virbr1' stp='on' delay='0'/>
  <mac address='52:54:00:18:37:a9'/>
  <ip address='192.168.123.1' netmask='255.255.255.0'>
    <dhcp>
      <range start='192.168.123.2' end='192.168.123.254'/>
    </dhcp>
  </ip>
</network>

posted @ 2023-05-12 16:43  lifei888  阅读(97)  评论(0)    收藏  举报