虚拟化技术之kvm虚拟机创建工具virt-install

  • A+
所属分类:linux技术
摘要

  在前边的博客中,我们创建KVM虚拟机用到了virt-manager,这个工具是一个图形化工具,创建虚拟机很方便;除此我们还是用virsh define/create +虚拟机配置文件来创建虚拟机,这种方式是通过配置文件的方式,我们把定义虚拟机的信息写成一个.xml格式的描述文件,然后使用virsh这个工具来读取配置文件,从而根据我们定义的配置文件创建虚拟机;今天我们来了解下直接在命令行使用virt-install命令的方式来创建虚拟机;

  在前边的博客中,我们创建KVM虚拟机用到了virt-manager,这个工具是一个图形化工具,创建虚拟机很方便;除此我们还是用virsh define/create +虚拟机配置文件来创建虚拟机,这种方式是通过配置文件的方式,我们把定义虚拟机的信息写成一个.xml格式的描述文件,然后使用virsh这个工具来读取配置文件,从而根据我们定义的配置文件创建虚拟机;今天我们来了解下直接在命令行使用virt-install命令的方式来创建虚拟机;

  1、virt-install的帮助信息

[root@node1 ~]# virt-install -h usage: virt-install --name NAME --memory MB STORAGE INSTALL [options]  从指定安装源创建新虚拟机。  optional arguments:   -h, --help            show this help message and exit   --version             show program's version number and exit   --connect URI         通过 libvirt URI 连接到虚拟机管理程序  通用选项:   -n NAME, --name NAME  客户机实例名称   --memory MEMORY       Configure guest memory allocation. Ex:                         --memory 1024 (in MiB)                         --memory 512,maxmemory=1024                         --memory 512,maxmemory=1024,hotplugmemorymax=2048,hotplugmemoryslots=2   --vcpus VCPUS         Number of vcpus to configure for your guest. Ex:                         --vcpus 5                         --vcpus 5,maxvcpus=10,cpuset=1-4,6,8                         --vcpus sockets=2,cores=4,threads=2   --cpu CPU             CPU model and features. Ex:                         --cpu coreduo,+x2apic                         --cpu host-passthrough                         --cpu host   --metadata METADATA   配置客户机元数据。例如:                         --metadata name=foo,title="My pretty title",uuid=...                         --metadata description="My nice long description"  安装方法选项:   --cdrom CDROM         光驱安装介质   -l LOCATION, --location LOCATION                         安装源 (例如:nfs:host:/path, http://host/path,                         ftp://host/path)   --pxe                 使用 PXE 协议从网络引导   --import              在已有的磁盘镜像中构建客户机   --livecd              将光驱介质视为 Live CD   -x EXTRA_ARGS, --extra-args EXTRA_ARGS                         将附加参数添加到由 --location                         引导的内核中   --initrd-inject INITRD_INJECT                         添加指定文件到由 --location 指定的 initrd                         根中   --os-variant DISTRO_VARIANT                         在客户机上安装的操作系统,例如:'fedor                         a18'、'rhel6'、'winxp' 等。   --boot BOOT           配置客户机引导设置。例如:                         --boot hd,cdrom,menu=on                         --boot init=/sbin/init (针对容器)   --idmap IDMAP         为 LXC 容器启用用户名称空间。例如:                         --idmap uid_start=0,uid_target=1000,uid_count=10  设备选项:   --disk DISK           指定存储的各种选项。例如:                         --disk size=10 (在默认位置创建 10GiB 镜像)                         --disk /my/existing/disk,cache=none                         --disk device=cdrom,bus=scsi                         --disk=?   -w NETWORK, --network NETWORK                         配置客户机网络接口。例如:                         --network bridge=mybr0                         --network network=my_libvirt_virtual_net                         --network network=mynet,model=virtio,mac=00:11...                         --network none                         --network help   --graphics GRAPHICS   配置客户机显示设置。例如:                         --graphics vnc                         --graphics spice,port=5901,tlsport=5902                         --graphics none                         --graphics vnc,password=foobar,port=5910,keymap=ja   --controller CONTROLLER                         配置客户机控制器设备。例如:                         --controller type=usb,model=ich9-ehci1   --input INPUT         配置客户机输入设备。例如:                         --input tablet                         --input keyboard,bus=usb   --serial SERIAL       配置客户机串口设备   --parallel PARALLEL   配置客户机并口设备   --channel CHANNEL     配置客户机通信通道   --console CONSOLE     配置文本控制台连接主机与客户机   --hostdev HOSTDEV     配置物理 USB/PCI 等主机设备与客户机共享   --filesystem FILESYSTEM                         传递主机目录到客户机。例如:                         --filesystem /my/source/dir,/dir/in/guest                         --filesystem template_name,/,type=template   --sound [SOUND]       配置客户机声音设备仿真   --watchdog WATCHDOG   配置客户机 watchdog 设备   --video VIDEO         配置客户机视频硬件。   --smartcard SMARTCARD                         配置客户机智能卡设备。例如:                         --smartcard mode=passthrough   --redirdev REDIRDEV   配置客户机重定向设备。例如:                         --redirdev usb,type=tcp,server=192.168.1.1:4000   --memballoon MEMBALLOON                         配置客户机 memballoon 设备。例如:                         --memballoon model=virtio   --tpm TPM             配置客户机 TPM 设备。例如:                         --tpm /dev/tpm   --rng RNG             Configure a guest RNG device. Ex:                         --rng /dev/urandom   --panic PANIC         配置客户机 panic 设备。例如:                         --panic default   --memdev MEMDEV       Configure a guest memory device. Ex:                         --memdev dimm,target_size=1024  客户机配置选项:   --security SECURITY   设置域安全驱动配置。   --cputune CPUTUNE     Tune CPU parameters for the domain process.   --numatune NUMATUNE   为域进程调整 NUMA 策略。   --memtune MEMTUNE     为域进程调整内存策略。   --blkiotune BLKIOTUNE                         为域进程调整 blkio 策略。   --memorybacking MEMORYBACKING                         为域进程设置内存后备策略。例如:                         --memorybacking hugepages=on   --features FEATURES   设置域 <features> XML。例如:                         --features acpi=off                         --features apic=on,eoi=on   --clock CLOCK         设置域 <clock> XML。例如:                         --clock offset=localtime,rtc_tickpolicy=catchup   --pm PM               配置 VM 电源管理功能   --events EVENTS       配置 VM 生命周期管理策略   --resource RESOURCE   配置 VM 资源分区(cgroups)   --sysinfo SYSINFO     Configure SMBIOS System Information. Ex:                         --sysinfo emulate                         --sysinfo host                         --sysinfo bios_vendor=Vendor_Inc.,bios_version=1.2.3-abc,...                         --sysinfo system_manufacturer=System_Corp.,system_product=Computer,...                         --sysinfo baseBoard_manufacturer=Baseboard_Corp.,baseBoard_product=Motherboard,...   --qemu-commandline QEMU_COMMANDLINE                         Pass arguments directly to the qemu emulator. Ex:                         --qemu-commandline='-display gtk,gl=on'                         --qemu-commandline env=DISPLAY=:0.1  虚拟化平台选项:   -v, --hvm             这个客户机应该是一个全虚拟化客户机   -p, --paravirt        这个客户机应该是一个半虚拟化客户机   --container           这个客户机应该是一个容器客户机   --virt-type HV_TYPE   要使用的管理程序名称 (kvm, qemu, xen, ...)   --arch ARCH           模拟 CPU 架构   --machine MACHINE     机器类型为仿真类型  其它选项:   --autostart           主机启动时自动启动域。   --transient           Create a transient domain.   --wait WAIT           请等待数分钟以便完成安装。   --noautoconsole       不要自动尝试连接到客户端控制台   --noreboot            安装完成后不启动客户机。   --print-xml [XMLONLY]                         打印生成的 XML 域,而不是创建客户机。   --dry-run             运行安装程序,但不创建设备或定义客户                         机。   --check CHECK         启用或禁用验证检查。例如:                         --check path_in_use=off                         --check all=off   -q, --quiet           抑制非错误输出   -d, --debug           输入故障排除信息  使用 '--option=?' 或 '--option help' 来查看可用的子选项 请参考 man 手册,以便了解示例和完整的选项语法。 [root@node1 ~]# 

  提示:如果要查看某一个选项的子选项,可以使用选项加?或者选项加--help来查看,如下所示

[root@node1 ~]# virt-install   --memorybacking ? --memorybacking options:   clearxml   hugepages   locked   nodeset   nosharepages   size   unit  [root@node1 ~]# virt-install   --memorybacking help --memorybacking options:   clearxml   hugepages   locked   nodeset   nosharepages   size   unit  [root@node1 ~]#

  2、创建一个虚拟机

  2.1、上传一个镜像到宿主机

[root@node1 ~]# cd /kvm/iso/ [root@node1 iso]# ls [root@node1 iso]# rz  rz waiting to receive.  zmodem trl+C ȡ    100%  811008 KB 26161 KB/s 00:00:31       0 Errors-1708.iso...  [root@node1 iso]# ls CentOS-7-x86_64-Minimal-1708.iso [root@node1 iso]# 

  提示:建议把镜像单独放在一个目录下;

  2.2、创建磁盘

[root@node1 iso]# cd [root@node1 ~]# cd /kvm/images/ [root@node1 images]# ls c1.qcow2  c2.qcow2  c3.qcow2  cirros-0.5.0-x86_64-disk.img [root@node1 images]# qemu-img create -f qcow2 ./centos7.qcow2 10G Formatting './centos7.qcow2', fmt=qcow2 size=10737418240 encryption=off cluster_size=65536 lazy_refcounts=off  [root@node1 images]# ll  总用量 41989476 -rw-r--r-- 1 root root      197120 8月  15 13:23 c1.qcow2 -rw------- 1 qemu qemu 21478375424 8月  18 13:07 c2.qcow2 -rw------- 1 root root 21478375424 8月  17 00:23 c3.qcow2 -rw-r--r-- 1 root root      197120 8月  18 13:08 centos7.qcow2 -rw-r--r-- 1 qemu qemu    40108032 8月  18 13:01 cirros-0.5.0-x86_64-disk.img [root@node1 images]#  

  提示:创建磁盘可以使用-o preallocation来指定磁盘分配策略,它支持 off, metadata, falloc, full,其中off表示不预分配(默认不指定就是这个),metadate,表示分配元素据信息,falloc表示随文件的增大而增大,full表示全部分配;

  2.3、创建虚拟机,并指定使用我们刚才上传的镜像

[root@node1 images]# virt-install --virt-type kvm --name c7 --ram 1024 --vcpus 2 --cdrom=/kvm/iso/CentOS-7-x86_64-Minimal-1708.iso --disk path=/kvm/images/centos7.qcow2 --network=default --graphics vnc,listen=0.0.0.0 --noautoconsole   开始安装...... 域安装仍在进行。您可以重新连接 到控制台以便完成安装进程。 [root@node1 images]# virsh list --all  Id    名称                         状态 ----------------------------------------------------  1     generic                        running  2     c2                             running  3     centos7.0                      running  4     c7                             running  [root@node1 images]#  

  提示:--virt-type用来指定虚拟机类型,--name用来指定创建的虚拟机名称,--ram 用于指定内存大小 --vcpus用于指定虚拟cpu核心数量 --cdrom用于指定关盘镜像文件位置 --disk path用于指定磁盘路径,--network用于指定网络名称 --graphics用于指定虚拟图形显卡,--noaustart用于指定不随宿主机启动而启动;到此虚拟机就创建好了,接下来我们需要用图像软件VNC或者virt-manager连接到虚拟机的控制台界面进行安装系统操作;

  3、使用vnc连接虚拟机安装操作系统

  3.1、查看宿主机上的监听端口情况

[root@node1 images]# ss -tnl State      Recv-Q Send-Q          Local Address:Port                         Peer Address:Port               LISTEN     0      1                           *:5903                                    *:*                   LISTEN     0      128                         *:111                                     *:*                   LISTEN     0      5               192.168.122.1:53                                      *:*                   LISTEN     0      128                         *:22                                      *:*                   LISTEN     0      128                 127.0.0.1:631                                     *:*                   LISTEN     0      100                 127.0.0.1:25                                      *:*                   LISTEN     0      128                 127.0.0.1:5900                                    *:*                   LISTEN     0      128                 127.0.0.1:5901                                    *:*                   LISTEN     0      128                 127.0.0.1:5902                                    *:*                   LISTEN     0      128                        :::111                                    :::*                   LISTEN     0      128                        :::22                                     :::*                   LISTEN     0      128                       ::1:631                                    :::*                   LISTEN     0      100                       ::1:25                                     :::*                   [root@node1 images]#  

  提示:默认情况vnc的第一个虚拟显示器(窗口)监听在5900这个端口,第二个窗口监听5901,依次类推;从上面的信息可以看到,我们宿主机上有4个vnc窗口,我们最后创建的虚拟机应该是第四个窗口,监听在5903这个端口;

  3.2、使用VNC连接宿主机的5903端口

虚拟化技术之kvm虚拟机创建工具virt-install

  提示:使用tightvnc viewer连接宿主机上的非第一个窗口需要在后面用双冒号+端口的方式来连接指定窗口;如果是第一个窗口直接写宿主机的ip地址即可;这里需要注意一点,用virsh或virt-manager创建的虚拟机,默认它是把vnc监听在127.0.0.1上,所以用外部的vnc软件是无法正常连接进去的;

虚拟化技术之kvm虚拟机创建工具virt-install

  提示:至此我们就可以安装虚拟机操作了,安装完成后重启即可;安装系统的过程就不过多演示了;

  3.3、创建windows系统虚拟机

  virtio 是一种 I/O 半虚拟化解决方案,是一套通用 I/O 设备虚拟化的程序,是对半虚拟化 Hypervisor 中的一组通用I/O 设备的抽象。提供了一套上层应用与各 Hypervisor 虚拟化设备(KVM,Xen,VMware等)之间的通信框架和编程接口,减少跨平台所带来的兼容性问题,大大提高驱动程序开发效率,windows 系统需要单独安装virtio驱动,linux系统自带virtio驱动。

  3.3.1、创建目录,并下载virtio驱动(根据安装的windos版本架构下载驱动)下载地址https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/archive-virtio/virtio-win-0.1.96/

[root@node1 kvm]# ls images  iso [root@node1 kvm]# mkdir virtio [root@node1 kvm]# cd virtio [root@node1 virtio]# wget https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/archive-virtio/virtio-win-0.1.96/virtio-win_amd64.vfd --2020-08-18 13:58:51--  https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/archive-virtio/virtio-win-0.1.96/virtio-win_amd64.vfd 正在解析主机 fedorapeople.org (fedorapeople.org)... 152.19.134.199, 2610:28:3090:3001:5054:ff:fea7:9474 正在连接 fedorapeople.org (fedorapeople.org)|152.19.134.199|:443... 已连接。 已发出 HTTP 请求,正在等待回应... 301 Moved Permanently 位置:https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/archive-virtio/virtio-win-0.1.96/virtio-win-0.1.96_amd64.vfd [跟随至新的 URL] --2020-08-18 13:58:54--  https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/archive-virtio/virtio-win-0.1.96/virtio-win-0.1.96_amd64.vfd 再次使用存在的到 fedorapeople.org:443 的连接。 已发出 HTTP 请求,正在等待回应... 200 OK 长度:2949120 (2.8M) [application/x-troff-man] 正在保存至: “virtio-win_amd64.vfd”  100%[====================================================================>] 2,949,120   8.04KB/s 用时 6m 8s    2020-08-18 14:05:03 (7.83 KB/s) - 已保存 “virtio-win_amd64.vfd” [2949120/2949120])  [root@node1 virtio]# ls virtio-win_amd64.vfd [root@node1 virtio]# pwd /kvm/virtio [root@node1 virtio]# 

  3.3.2、上传镜像

[root@node1 images]# cd ../iso/ [root@node1 iso]# ls CentOS-7-x86_64-Minimal-1708.iso [root@node1 iso]# rz rz waiting to receive.  zmodem trl+C ȡ    100% 3189038 KB 27025 KB/s 00:01:58       0 Errors_with_sp1_x64_dvd_u_677685.iso...  [root@node1 iso]# ll 总用量 4000048 -rw-r--r-- 1 qemu qemu  830472192 2月  22 2018 CentOS-7-x86_64-Minimal-1708.iso -rw-r--r-- 1 root root 3265574912 3月   6 2018 cn_windows_7_enterprise_with_sp1_x64_dvd_u_677685.iso [root@node1 iso]#  

  3.3.3、创建磁盘

[root@node1 iso]# cd ../virtio/ [root@node1 virtio]# qemu-img create -f qcow2 /kvm/images/win7.qcow2 50G Formatting '/kvm/images/win7.qcow2', fmt=qcow2 size=53687091200 encryption=off cluster_size=65536 lazy_refcounts=off  [root@node1 virtio]# ls /kvm/images/win7.qcow2  /kvm/images/win7.qcow2 [root@node1 virtio]# 

  3.3.4、创建虚拟机

[root@node1 virtio]# virt-install --virt-type kvm --name win7 --ram 1024 --vcpus=2 --os-type=windows --cdrom=/kvm/iso/cn_windows_7_enterprise_with_sp1_x64_dvd_u_677685.iso --disk path=/kvm/images/win7.qcow2,format=qcow2,bus=virtio --disk path=/kvm/virtio/virtio-win_amd64.vfd,device=floppy --network=default --graphics vnc,listen=0.0.0.0 --noautoconsole    开始安装...... 域安装仍在进行。您可以重新连接 到控制台以便完成安装进程。 [root@node1 virtio]# virsh list --all  Id    名称                         状态 ----------------------------------------------------  1     win7                           running  -     c2                             关闭  -     c7                             关闭  -     centos7.0                      关闭  -     generic                        关闭  [root@node1 virtio]# ss -tnl State       Recv-Q Send-Q        Local Address:Port                       Peer Address:Port               LISTEN      0      1                         *:5900                                  *:*                   LISTEN      0      128                       *:111                                   *:*                   LISTEN      0      5             192.168.122.1:53                                    *:*                   LISTEN      0      128                       *:22                                    *:*                   LISTEN      0      128               127.0.0.1:631                                   *:*                   LISTEN      0      100               127.0.0.1:25                                    *:*                   LISTEN      0      128                      :::111                                  :::*                   LISTEN      0      128                      :::22                                   :::*                   LISTEN      0      128                     ::1:631                                  :::*                   LISTEN      0      100                     ::1:25                                   :::*                   [root@node1 virtio]# 

   提示:可以看到虚拟机已经创建好了,并跑起来了,对应vnc5900端口也处于监听状态;

  3.3.5、用vnc连接虚拟机控制台,安装系统

虚拟化技术之kvm虚拟机创建工具virt-install

虚拟化技术之kvm虚拟机创建工具virt-install

虚拟化技术之kvm虚拟机创建工具virt-install

虚拟化技术之kvm虚拟机创建工具virt-install

虚拟化技术之kvm虚拟机创建工具virt-install

虚拟化技术之kvm虚拟机创建工具virt-install

 虚拟化技术之kvm虚拟机创建工具virt-install

  提示:这个根据自己安装的系统来选就可以了;

虚拟化技术之kvm虚拟机创建工具virt-install

  提示:如果能够把我们创建的磁盘识别到,说明我们的驱动选择是正确的,否则你需要更改驱动;

虚拟化技术之kvm虚拟机创建工具virt-install

  提示:等这个安装完成后重启,windows系统就装到我们创建的虚拟机上了;需要注意一点这个界面重启,虚拟机不会自动启动,需要我们手动的去启动虚拟机,才能下面的安装,安装完成后如下图所示;

虚拟化技术之kvm虚拟机创建工具virt-install

  到此基于virt-install工具在命令行创建windows虚拟机,结合vnc连接到虚拟机上安装操作系统的过程就结束了;其实在生产中,我们更本不会这样用,因为生产上用的虚拟机数量往往很大,用人为手动的方式去安装显然是不行的;我们可以借助自动化工具pxe+kickstart 或者使用cobbler配合这些自动化安装系统的工具来安装系统,我们只需要使用脚本把创建虚拟机的命令写好,创建好网络配置好网络,磁盘创建命令写好,一个脚本我们可以批量创建很多台虚拟机;有关pxe服务器和cobbler服务器的搭建,有兴趣的可以参考本人博客《Linux系统自动化安装之pxe实现》和《Linux系统自动化安装之cobbler实现》;