VMware Workstation 26.0.0 在 Ubuntu 24.04 (内核 6.17.0) 上的安装与内核模块编译问题

环境信息

项目 版本
操作系统 Ubuntu 24.04.3 LTS (Noble Numbat)
内核版本 6.17.0-29-generic
VMware Workstation 26.0.0 (Build 25388281)
CPU 13th Gen Intel Core i7-1360P
Secure Boot 已启用

问题现象

  1. 安装完成后首次启动 ,弹出 "VMware Kernel Module Updater" 窗口,提示 GCC 13.3.0 未找到

  2. 安装 GCC 和内核头文件后,模块编译仍失败,日志显示:

    复制代码
    No matching PBM set was found for kernel "6.17.0-29-generic"
    Virtual machine monitor      failed
    Virtual ethernet             failed
  3. 根本原因:VMware 26.0.0 原生不支持 Linux 6.17 内核,需要打兼容性补丁


解决步骤

1. 安装基础依赖

bash 复制代码
sudo apt update
sudo apt install -y gcc-13 g++-13 build-essential \
    linux-headers-$(uname -r) git dkms

2. 下载自动补丁工具

bash 复制代码
cd ~/下载
git clone https://github.com/Hyphaed/vmware-vmmon-vmnet-linux-6.17.x.git vmware-patcher
cd vmware-patcher

3. 运行自动补丁脚本

bash 复制代码
sudo python3 vmware_module_builder.py
  • 选择编译模式:2) Optimized(针对 CPU 优化)
  • 脚本自动完成:
    • 备份原始 VMware 源码
    • 应用 6.17 内核兼容性补丁(objtool、netif_napi_add、do_gettimeofday 等)
    • 编译 vmmonvmnet 模块
    • 安装模块并创建开机自启服务

4. 处理 Secure Boot 模块签名

由于 Secure Boot 已启用,编译后的未签名模块被拒绝加载:

复制代码
modprobe: ERROR: could not insert 'vmmon': Key was rejected by service
4.1 创建 MOK 密钥
bash 复制代码
# 创建密钥对
sudo mkdir -p /var/lib/shim-signed/mok
cd /var/lib/shim-signed/mok
sudo openssl req -new -x509 -newkey rsa:2048 \
    -keyout MOK.priv -outform DER -out MOK.der \
    -days 36500 -nodes \
    -subj "/CN=VMware Module Signing Key/"

# 导入 Secure Boot(设置密码后重启注册)
sudo mokutil --import MOK.der
sudo reboot

重启后在蓝色 MOK 界面:Enroll MOK → Continue → Yes → 输入密码 → Reboot

4.2 签名模块
bash 复制代码
sudo /usr/src/linux-headers-6.17.0-29-generic/scripts/sign-file sha256 \
    /var/lib/shim-signed/mok/MOK.priv \
    /var/lib/shim-signed/mok/MOK.der \
    /lib/modules/6.17.0-29-generic/misc/vmmon.ko

sudo /usr/src/linux-headers-6.17.0-29-generic/scripts/sign-file sha256 \
    /var/lib/shim-signed/mok/MOK.priv \
    /var/lib/shim-signed/mok/MOK.der \
    /lib/modules/6.17.0-29-generic/misc/vmnet.ko

5. 启动服务

bash 复制代码
sudo modprobe vmmon
sudo modprobe vmnet
sudo systemctl restart vmware.service

验证结果

bash 复制代码
$ lsmod | grep -E "vmmon|vmnet|vmw_vmci"
vmnet                  77824  13
vmmon                 188416  0
vmw_vmci              106496  1 vmw_vsock_vmci_transport
bash 复制代码
$ sudo systemctl status vmware.service
● vmware.service - VMware Workstation Services
     Active: active (running)

VMware Workstation 正常运行,虚拟机可以启动。


后续维护

场景 操作
内核/VMware 更新后模块失效 重新运行补丁脚本 + 用已有 MOK 密钥重新签名
不想每次签名 进 BIOS 禁用 Secure Boot
模块已签名 + MOK 已注册 重启后自动加载,无需额外操作

关键要点

要点 说明
GCC 只是第一步 安装 GCC 后,VMware 26.0.0 对 6.17 内核的原生不支持才是核心问题
社区补丁工具很关键 vmware_module_builder.py 自动处理了所有 6.17 兼容性补丁
Secure Boot 是最后障碍 模块编译成功后,签名是加载的必要条件
MOK 注册只需一次 密钥注册到 Secure Boot 后,后续只需重新签名模块,无需重复注册
相关推荐
tntxia5 小时前
linux curl命令详解_curl详解
linux
扛枪的书生8 小时前
Linux 网络管理器用法速查
linux
顺风尿一寸11 小时前
Java Socket 内核之旅:从 SocketChannel.read() 到 tcp_recvmsg 与 epoll 的完整调用链路
linux
XIAOHEZIcode17 小时前
Ubuntu 终端美化全栈指南:Bash 到 Kitty 踩坑实录
linux·ubuntu·命令行
唐青枫19 小时前
别再只会用 cron:Linux systemd Timer 定时任务实战详解
linux
AlfredZhao3 天前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
武子康4 天前
调查研究-197 FAISS vs Elasticsearch 全面对比:从向量检索、全文搜索到 RAG 选型指南
人工智能·elasticsearch·agent
戴为沐4 天前
Linux内存扩容指南
linux
zylyehuo4 天前
Linux 彻底且安全地删除文件
linux
用户805533698035 天前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式