Virtual Box安装后需要进行内核模块的编译及安装;为了减少目标机器的编译过程,将内核模块的编译过程放到了编译环境,生产环境只对内核模块进行insert。根据这个思路,把Virtual Box编译生成的内核模块vboxdrv.ko vboxnetflt.ko vboxnetadp.ko三个文件,打包成rpm包,而后在自启动的时候,使用insmod将内核模块插入;
在实践过程中,发现lsmod可以查看到模块正常插入;通过dmesg也可以查看到三个模块的正确加载信息;
但是在使用systemctl status vboxdrv时发现调用modprobe vboxnetflt提示了错误信息
[root@localhost init.d]# systemctl status vboxdrv
● vboxdrv.service - VirtualBox Linux kernel module
Loaded: loaded (/usr/lib/virtualbox/vboxdrv.sh; enabled; vendor preset: disabled)
Active: failed (Result: exit-code) since 一 2024-05-13 17:00:36 CST; 1h 4min ago
Process: 10125 ExecStart=/usr/lib/virtualbox/vboxdrv.sh start (code=exited, status=1/FAILURE)
5月 13 17:00:36 localhost.localdomain systemd[1]: Starting VirtualBox Linux kernel module...
5月 13 17:00:36 localhost.localdomain vboxdrv.sh[10125]: vboxdrv.sh: Starting VirtualBox services.
5月 13 17:00:36 localhost.localdomain vboxdrv.sh[10125]: vboxdrv.sh: failed: modprobe vboxnetflt failed. Please use 'dmesg' to find out why.
单独执行modprobe vboxnetflt提示模块找不到
后发现depmod命令,是更新内核模块符号及依赖信息的命令;通过执行depmod后,相关命令可以正常运行;
所以把depmod命令加入到安装内核的rpm包的脚本中,即可解决该问题;