免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: platinum
打印 上一主题 下一主题

[已解决]有什么好的办法可以保存 kernel panic 信息? [复制链接]

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
51 [报告]
发表于 2010-06-01 12:02 |只看该作者
但是我有一个不明白,直接运行有问题,派生线程就没事了吗?
这个和程序线性、并行运行有什么关系吗?

直接运行是怎么实现的。采用什么方式截获系统发生oops了。用个循环一直去检查吗?

论坛徽章:
0
52 [报告]
发表于 2010-06-01 12:08 |只看该作者
在 arch/i386/kernel/traps.c 里,有很多 printk 语句,屏幕上那些信息即使这里产生的
我尝试在这个位置把一个自己的 string 写入文件
但是在调用 flip_open 的时候就 panic 嵌套了

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
53 [报告]
发表于 2010-06-01 13:13 |只看该作者
在 arch/i386/kernel/traps.c 里,有很多 printk 语句,屏幕上那些信息即使这里产生的
我尝试在这个位置把 ...
platinum 发表于 2010-06-01 12:08


白金兄,你这样试一下。
将traps.c中所有用于打印oops信息的printk时,同时将这份信息也记录到一个缓冲里面。
然后你通过另外一个模块,开启一个内核线程,在满足一定条件的时候,将那个全局缓冲的数据写到文件中。然后直接重启系统得了。

论坛徽章:
0
54 [报告]
发表于 2010-06-01 13:28 |只看该作者
白金兄,你这样试一下。
将traps.c中所有用于打印oops信息的printk时,同时将这份信息也记录到一个缓冲 ...
Godbach 发表于 2010-06-01 13:13

有点麻烦,因为 OOPS 那些信息是通过很多方法获取到的,我如果想实现你说的,必须要修改每一个 print 函数,把数据汇总到一起
不过我可以根据你的提议先测试一下通知外挂模块写文件
你觉的用什么方式通知外挂模块比较好?

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
55 [报告]
发表于 2010-06-01 13:32 |只看该作者
有点麻烦,因为 OOPS 那些信息是通过很多方法获取到的,我如果想实现你说的,必须要修改每一个 print 函数,把数据汇总到一起

可以在每个用于打印oops信息的printk后面加上你的保存信息函数即可。这样也不影响系统原始的输出oops的方式。

不过我可以根据你的提议先测试一下通知外挂模块写文件
你觉的用什么方式通知外挂模块比较好?

可以考虑用个队列啥的。不过很显然,traps.c应该做配套的修改吧。

论坛徽章:
0
56 [报告]
发表于 2010-06-01 13:49 |只看该作者
我现在想的实验方法是
1、编写一个 module,接收内核信号,得到信号后写一个 string 到文件中
2、在 OOPS 的 traps 代码中嵌入一个功能,发送信号给那个 module

现在的问题是,这个信号用什么实现?要求做到 module 被动立即触发的模式……

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
57 [报告]
发表于 2010-06-01 13:50 |只看该作者
现在的问题是,这个信号用什么实现?要求做到 module 被动立即触发的模式……

通知链或者队列都可以吧,trap.c中发出通知或者wake_up,你的模块中接收到这个信息,就执行某个动作。

论坛徽章:
0
58 [报告]
发表于 2010-06-01 13:52 |只看该作者
通知链或者队列都可以吧,trap.c中发出通知或者wake_up,你的模块中接收到这个信息,就执行某个动作。
Godbach 发表于 2010-06-01 13:50

好的,我去查一下相关技术,以前没有接触过这个层面的知识

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
59 [报告]
发表于 2010-06-01 13:56 |只看该作者
LDD3中介绍过队列,白金兄可以看一下书。

论坛徽章:
0
60 [报告]
发表于 2010-06-01 14:48 |只看该作者
收集kernel panic之前日志信息很感兴趣,无奈对linux不是熟悉,有好办法可以指点一下吗

除了照相机
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP