免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4288 | 回复: 8

请问如何查看一个进程不正常退出的信息? [复制链接]

论坛徽章:
0
发表于 2010-06-21 17:04 |显示全部楼层
大家好,我的一个后台程序在运行的时候总莫名其妙的退出,标准错误和标准输出已经指向日志文件了,但是里面只有普通的日志信息,没有程序的出错信息,由于退出是不定时的,有可能是一天才发生也有可能是几个小时,我没法在控制台下看到,请问我该怎么查看该进程的退出信息,或者我该怎么修改程序可以把这个错误信息输入到日志文件里。哪位大侠指点下呗!

论坛徽章:
34
亥猪
日期:2015-03-20 13:55:11戌狗
日期:2015-03-20 13:57:01酉鸡
日期:2015-03-20 14:03:56未羊
日期:2015-03-20 14:18:30子鼠
日期:2015-03-20 14:20:14丑牛
日期:2015-03-20 14:20:31辰龙
日期:2015-03-20 14:35:34巳蛇
日期:2015-03-20 14:35:56操作系统版块每日发帖之星
日期:2015-11-06 06:20:00操作系统版块每日发帖之星
日期:2015-11-08 06:20:00操作系统版块每日发帖之星
日期:2015-11-19 06:20:00黄金圣斗士
日期:2015-11-24 10:43:13
发表于 2010-06-21 18:55 |显示全部楼层
如果这个程序出错停止了,应该是由另一个程序报告吧?

论坛徽章:
0
发表于 2010-06-21 21:33 |显示全部楼层
这个程序停止就停止了,没有另外的程序,这是一个多线程的程序,你的意思是我另外再写一个程序,把这个程序作为它的子进程?就可以收集到退出信息了?

论坛徽章:
0
发表于 2010-06-24 12:02 |显示全部楼层
可以试一试ulimit -c unlimited,能够生成core文件

论坛徽章:
0
发表于 2010-06-28 16:25 |显示全部楼层
可以在程序中加上log信息,写入到某个文件里, 把你认为可能出错的地方加上异常处理

论坛徽章:
0
发表于 2010-06-28 16:59 |显示全部楼层
回复 4# ljysyn


    严重同意此做法!
   你程序很可能由于操作非法地址或死锁等原因down掉了,这种随即现象的跟踪只能用 dump core 了,然后再用GDB调试就能发现bug。

论坛徽章:
34
亥猪
日期:2015-03-20 13:55:11戌狗
日期:2015-03-20 13:57:01酉鸡
日期:2015-03-20 14:03:56未羊
日期:2015-03-20 14:18:30子鼠
日期:2015-03-20 14:20:14丑牛
日期:2015-03-20 14:20:31辰龙
日期:2015-03-20 14:35:34巳蛇
日期:2015-03-20 14:35:56操作系统版块每日发帖之星
日期:2015-11-06 06:20:00操作系统版块每日发帖之星
日期:2015-11-08 06:20:00操作系统版块每日发帖之星
日期:2015-11-19 06:20:00黄金圣斗士
日期:2015-11-24 10:43:13
发表于 2010-06-28 17:20 |显示全部楼层
一个人死的时候,要么自己留下遗书,要不就得让别人看见啊。

论坛徽章:
0
发表于 2010-06-28 18:32 |显示全部楼层
openlog 和 syslog 函数应该可以帮助你

论坛徽章:
0
发表于 2010-06-28 20:55 |显示全部楼层
同意8楼的作法 跟守护进程程序一样 不好调试 你就可以采用这样的方法来看调试信息。

或者 这样也可以

比如你的程序名为 main
在执行的时候重定向一下 ./main > /tmp/log.txt
程序异常以后再查看/tmp/log.txt也应该是可以的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP