需安装qemu-system-x86、qemu-utils、virt-manager三个包;启用KVM需加载内核模块、加用户至kvm组并重登;运行虚拟机须指定OVMF固件、qcow2磁盘及virtio网卡。

Ubuntu/Debian 上装 qemu-system-x86\_64 要装哪几个包
只装 qemu 包不够,它默认是精简版,不带 KVM 支持和图形界面。实际跑 x86\_64 虚拟机必须装全:qemu-system-x86(核心模拟器)、qemu-utils(磁盘管理工具)、virt-manager(可选但强烈建议,GUI 更直观)。
常见错误现象:运行 qemu-system-x86_64 报错 command not found,或启动后卡在黑屏、CPU 占用 100% —— 大概率是只装了 qemu 或 qemu-user 这类非系统级包。
- 执行
sudo apt update && sudo apt install qemu-system-x86 qemu-utils virt-manager - 装完检查:
qemu-system-x86_64 --version应输出版本号;ls /usr/bin/qemu-system-*应看到 x86\_64、aarch64 等多个二进制 - 如果用的是 CentOS/RHEL 8+,对应命令是
sudo dnf install @virtualization,它会拉齐 libvirt、qemu-kvm、virt-install 等一整套
验证 KVM 是否启用,否则性能差十倍
KVM 不是默认自动开启的。没启用时,QEMU 只能纯软件模拟(TCG 模式),启动慢、运行卡、CPU 占满——尤其跑 Linux 发行版镜像时特别明显。
判断依据不是看有没有 /dev/kvm 文件,而是看当前用户能否读写它。很多教程漏掉权限配置这步,导致 virt-manager 提示 “Unable to connect to libvirt” 或启动虚拟机报 Could not access KVM kernel module: Permission denied。
- 先确认 CPU 支持:
grep -E "(vmx|svm)" /proc/cpuinfo,有输出才可能启用 KVM - 加载模块:
sudo modprobe kvm-intel(Intel)或sudo modprobe kvm-amd(AMD) - 加用户到
kvm组:sudo usermod -a -G kvm $USER,然后彻底退出重登(仅newgrp不够) - 验证:
ls -l /dev/kvm权限应含crw-rw----且组为kvm;再跑qemu-system-x86_64 -accel kvm -cpu host -S -monitor stdio -nographic -kernel /dev/null 2>&1 | grep "KVM",看到Using KVM才算真启用
创建一个最小可用虚拟机:别直接用 raw 镜像启动
新手常犯的错是下载个 ISO 就直接 qemu-system-x86_64 -cdrom ubuntu-22.04.iso,结果鼠标键盘失灵、网络不通、安装完无法重启——因为缺设备模型、BIOS、磁盘和网卡驱动支持。
真正能跑起来的最小命令,得明确指定机器类型、固件(OVMF for UEFI)、磁盘格式(qcow2 支持快照和稀疏分配)、网卡模型(virtio-net-pci 性能远好于 e1000)。
- 建磁盘:
qemu-img create -f qcow2 ubuntu.qcow2 20G - 启动安装:
qemu-system-x86_64 -m 2G -cpu host -smp 2 -bios /usr/share/ovmf/OVMF.fd -drive file=ubuntu.qcow2,format=qcow2 -cdrom ubuntu-22.04.iso -netdev user,id=net0 -device virtio-net-pci,netdev=net0 - 注意路径:
/usr/share/ovmf/OVMF.fd在 Ubuntu/Debian 是标准位置;若提示找不到,装ovmf包;CentOS 对应是/usr/share/edk2/ovmf/OVMF_CODE.fd - 安装完成后去掉
-cdrom参数,直接qemu-system-x86_64 -drive file=ubuntu.qcow2,format=qcow2 ...启动已装好的系统
libvirt + virt-manager 是省事关键,但别跳过初始配置
不用 libvirt 也能硬敲 QEMU 命令,但每次改内存、加硬盘、调网络都得重写一长串参数。virt-manager 本质是 libvirt 的前端,它把配置存成 XML,下次双击就能续上——前提是 libvirtd 服务在运行、且你有权限操作默认连接 qemu:///system。
最容易被忽略的是:Ubuntu 安装 virt-manager 后,libvirtd 默认不自启,且普通用户无权连 qemu:///system。此时打开 virt-manager 是空界面,点“新建”卡住,日志里全是 Connection refused。
- 启动服务:
sudo systemctl enable --now libvirtd - 确认 socket 存在:
ls /var/run/libvirt/libvirt-sock(system 连接用这个) - 加用户到
libvirt组:sudo usermod -a -G libvirt $USER,同样需重新登录 - 首次打开 virt-manager,左下角选 “QEMU/KVM”,右键“localhost (QEMU)” → “Details” → “Virtual Networks” → 确保 “default” 网络状态是 “Active”;如不是,点右下角“Apply”启动它
真正麻烦的从来不是装几个包,而是每个组件之间那几处权限、路径、服务状态的咬合点。少验一个,后面就卡在某个看似无关的环节里。










