免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3271 | 回复: 2
打印 上一主题 下一主题

[内核入门] 安装了kernel-devel和kernel-debug,运行systemtap脚本仍然找不到模块 [复制链接]

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 10:16:532015元宵节徽章
日期:2015-03-06 15:53:22
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2017-03-23 20:00 |只看该作者 |倒序浏览
本帖最后由 cdsfiui 于 2017-03-23 20:07 编辑

我有两个环境,centos6.8和ubuntu16.04,都在virtualbox里面做了64位版本的虚拟机。在centos6.8上面安装了这两个包,如下信息:

  1. # yum install kernel-devel
  2. 已加载插件:fastestmirror, refresh-packagekit, security
  3. ...
  4. 包 kernel-devel-2.6.32-642.15.1.el6.x86_64 已安装并且是最新版本
  5. 无须任何处理

  6. # yum install kernel-debug
  7. 已加载插件:fastestmirror, refresh-packagekit, security
  8. ...
  9. 包 kernel-debug-2.6.32-642.15.1.el6.x86_64 已安装并且是最新版本
  10. 无须任何处理
复制代码

ubuntu上面也已经

  1. sudo apt-get install linux-headers-`uname -r`以及
  2. sudo apt-get install fakeroot build-essential crash kexec-tools makedumpfile kernel-wedge(不知道是不是还缺东西)
复制代码

两个环境都可以运行 stap -ve 'probe begin { log("hello world") exit() }' 没有问题。

然后我有这个.stp脚本,网上找到的一个入门的例子:

  1. cat test2.stp
  2. #!/usr/bin/stap
  3. probe begin
  4. {
  5.     log("开始probe")
  6. }
  7. probe syscall.open
  8. {
  9.     printf("%s(%d) open (%s)\n",execname(),pid(),argstr)
  10. }
  11. probe timer.ms(4000)#4秒以后
  12. {
  13.     exit()
  14. }
  15. probe end
  16. {
  17.     log("结束probe")
  18. }
复制代码

chmod+x这个脚本,然后用root来执行,两个环境都报出一堆的错误:

  1. $ sudo ./test2.stp
  2. [sudo] me 的密码:
  3. semantic error: while resolving probe point: identifier 'kernel' at /usr/share/systemtap/tapset/linux/syscalls2.stp:197:24
  4.         source: probe __syscall.open = kernel.function("sys_open").call
  5.                                        ^

  6. semantic error: missing x86_64 kernel/module debuginfo [man warning::debuginfo] under '/lib/modules/4.4.0-38-generic/build'

  7. semantic error: while resolving probe point: identifier '__syscall' at :177:47
  8.         source: probe syscall.open = __syscall.compat_open ?, __syscall.open
  9.                                                               ^

  10. semantic error: no match

  11. Pass 2: analysis failed.  [man error::pass2]
  12. Number of similar error messages suppressed: 1.
  13. Rerun with -v to see them.
  14. Tip: /usr/share/doc/systemtap/README.Debian should help you get started.
复制代码
这个是语法错误,还是缺少什么环境的依赖?

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
2 [报告]
发表于 2017-03-27 14:31 |只看该作者
缺少kernel的debuginfo

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
3 [报告]
发表于 2017-03-27 14:51 |只看该作者
http://ddebs.ubuntu.com/pool/main/l/linux/找对应版本的ddeb包。

评分

参与人数 1信誉积分 +10 收起 理由
cdsfiui + 10 很给力!

查看全部评分

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP