免费注册 查看新帖 |

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
发表于 2010-06-01 12:02 |显示全部楼层
但是我有一个不明白,直接运行有问题,派生线程就没事了吗?
这个和程序线性、并行运行有什么关系吗?

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

论坛徽章:
0
发表于 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
发表于 2010-06-01 13:13 |显示全部楼层
在 arch/i386/kernel/traps.c 里,有很多 printk 语句,屏幕上那些信息即使这里产生的
我尝试在这个位置把 ...
platinum 发表于 2010-06-01 12:08


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

论坛徽章:
0
发表于 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
发表于 2010-06-01 13:32 |显示全部楼层
有点麻烦,因为 OOPS 那些信息是通过很多方法获取到的,我如果想实现你说的,必须要修改每一个 print 函数,把数据汇总到一起

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

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

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

论坛徽章:
0
发表于 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
发表于 2010-06-01 13:50 |显示全部楼层
现在的问题是,这个信号用什么实现?要求做到 module 被动立即触发的模式……

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

论坛徽章:
0
发表于 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
发表于 2010-06-01 13:56 |显示全部楼层
LDD3中介绍过队列,白金兄可以看一下书。

论坛徽章:
0
发表于 2010-06-01 14:48 |显示全部楼层
收集kernel panic之前日志信息很感兴趣,无奈对linux不是熟悉,有好办法可以指点一下吗

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

本版积分规则 发表回复

DTCC2020中国数据库技术大会

【架构革新 高效可控】2020年12月21日-23日第十一届中国数据库技术大会将在北京隆重召开。

大会设置2大主会场,20+技术专场,将邀请超百位行业专家,重点围绕数据架构、AI与大数据、传统企业数据库实践和国产开源数据库等内容展开分享和探讨,为广大数据领域从业人士提供一场年度盛会和交流平台。

http://dtcc.it168.com


大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP