insmod后modinfo查找不到信息的错误

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包的脚本中,即可解决该问题;

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值