1. VM中的进程和线程是如何在物理机(宿主机)上体现的?
在Qemu进程中,通过对每个vCPU创建线程,然后调用ioctl_kvm系统调用陷入VMEntry,进入到non-root模式,去执行Guest操作系统代码。
从物理机视角,对每个vCPU都是一个物理机上的线程,并且在qemu的进程中。
但从Guest的角度来看,进入到虚拟机中之后,仍然可以创建很多进程和线程,这些进程和线程在宿主机上是如何表现的?即若虚拟机中创建一个进程,宿主机上的qemu进程中的线程数量会增加吗?
答案是否定的,因为在宿主机上看到的线程数量都是记录在宿主机上的操作系统中的,虚拟机中的进程和线程信息是记录在虚拟机的操作系统中的。从宿主机角度而言,vCPU只是qemu中线程的一部分,但是从虚拟机角度而言,这些vCPU却是逻辑CPU,也就是逻辑进程。在虚拟机中创建进程和线程也就是利用这些vCPU进行调度,对于宿主机来讲就是这些vCPU在执行代码。因此基于这些vCPU在虚拟机内部创建的进程和线程对宿主机是不透明的。
2. qemu进程中的线程数量远远大于vCPU的数量,是为什么?
查看qemu进程:
[root@node1 ~]# ps -aux |grep kvm
root 446079 3.4 3.7 9775812 2469404 ? Sl Mar29 706:02 /usr/libexec/qemu-kvm -name guest=instance-0000001f,debug-threads=on -S -object secret,id=masterKey0,format=raw,file=/var/lib/libvirt/qemu/domain-1-instance-0000001f/master-key.aes -machine pc-i440fx-rhel7.6.0,accel=tcg,usb=off,dump-guest-core=off -cpu EPYC,acpi=on,ss=on,hypervisor=on,erms=on,mpx=on,pcommit=on,clwb=on,pku=on,la57=on,3dnowext=on,3dnow=on,npt=on,vme=off,fma=off,avx=off,f16c=off,avx2=off,rdseed=off,sha-ni=off,xsavec=off,fxsr-opt=off,misalignsse=off,3dnowprefetch=off,osvw=off,topoext=off,nrip-save=off -m 4096 -overcommit mem-lock&#