kvm虚拟化启用需五步:一、确认cpu支持vmx或svm;二、bios中开启vt-x/amd-v;三、加载kvm及对应厂商模块并确保/dev/kvm存在;四、安装qemu-kvm、libvirt等软件包并启动libvirtd服务;五、将用户加入libvirt和kvm组以获访问权限。

如果您尝试在Linux系统上运行KVM虚拟机,但遇到“KVM acceleration not available”或“VT-x is disabled”等错误提示,则很可能是CPU硬件虚拟化未启用或KVM内核模块未加载。以下是启用KVM虚拟化的完整操作路径:
一、确认CPU支持硬件虚拟化
该步骤用于验证处理器是否具备Intel VT-x(vmx)或AMD-V(svm)能力,是启用KVM的前提条件。
1、执行命令检查CPU标志位:egrep -c '(vmx|svm)' /proc/cpuinfo
2、若输出结果为0,说明当前CPU不支持硬件虚拟化,或BIOS中该功能被禁用。
3、进一步区分厂商:执行grep vmx /proc/cpuinfo(Intel)或grep svm /proc/cpuinfo(AMD),有输出即表示CPU原生支持。
二、在BIOS/UEFI中启用虚拟化技术
即使CPU支持,也必须在固件层显式开启VT-x或AMD-V,否则Linux内核无法调用底层虚拟化指令集。
1、重启服务器或物理主机,在启动自检阶段反复按指定键(常见为Del、F2、F10、F12,具体依主板品牌而定)进入BIOS/UEFI设置界面。
2、导航至Advanced → CPU Configuration或Security → Virtualization Technology等类似路径。
3、将Intel Virtualization Technology(VT-x)或SVM Mode(AMD-V)设置为Enabled。
4、同时检查Intel VT-d(I/O虚拟化)是否启用,该选项对PCI直通等功能至关重要。
5、保存设置并退出(通常为F10 → Yes),系统自动重启。
三、验证并加载KVM内核模块
BIOS启用后,需确保Linux内核已正确识别并加载对应KVM模块,生成/dev/kvm设备节点。
1、重启后执行:lsmod | grep kvm,应看到kvm及kvm_intel(Intel)或kvm_amd(AMD)模块已载入。
2、若无输出,手动加载:modprobe kvm && modprobe kvm_intel(Intel)或modprobe kvm && modprobe kvm_amd(AMD)。
3、确认设备节点存在:ls -l /dev/kvm,返回结果应包含crw-rw-rw-权限且主设备号为10,次设备号为232。
4、为使模块开机自动加载,执行:echo "kvm" >> /etc/modules && echo "kvm_intel" >> /etc/modules(Intel)或替换为kvm_amd(AMD)。
四、安装KVM基础软件包并启动服务
仅启用内核模块不足以管理虚拟机,还需安装用户态工具链与libvirt守护进程,构成完整虚拟化栈。
1、对于RHEL/CentOS/AlmaLinux 7/8/9:yum install -y qemu-kvm libvirt virt-install virt-manager bridge-utils
2、对于Debian/Ubuntu:apt update && apt install -y qemu-kvm libvirt-daemon-system virtinst virt-manager
3、启动并启用libvirtd服务:systemctl start libvirtd && systemctl enable libvirtd
4、验证服务状态:systemctl status libvirtd,确保Active状态为running。
五、将当前用户加入libvirt与kvm组
非root用户默认无权访问/libvirt/qemu和/dev/kvm设备,需通过组权限授权以实现无密码调用虚拟化功能。
1、执行命令添加用户到必要组:usermod -a -G libvirt,kvm $USER
2、立即生效需重新登录终端,或运行:newgrp libvirt && newgrp kvm
3、验证组成员身份:groups,输出中应包含libvirt和kvm。
4、测试基本功能:virsh list --all,若无报错即表示权限配置成功。










