免费注册 查看新帖 |

Chinaunix

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

[系统] [结贴]strace似乎不能跟踪多线程程序啊? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-05-22 10:05 |只看该作者 |倒序浏览
本帖最后由 weichuang02 于 2013-05-31 09:34 编辑

我的一个正在开发的程序是多线程的,里面很多pthread的东西。运行几个小时之后出了问题,因此我想用strace来跟踪进程的运行。

进程重启后,我strace -p <进程pid>
然后打印了3行以后,就没有别的内容了:
[root@xxxx]strace -p 24091
Process xxx attached - interrupt to quit
[ Process PID=24091 runs in 32 bit mode. ]
futex(0xc5bbbd8, FUTEX_WAIT, 24215 NULL


然后就再也没有输出了。我用的是RHEL6.3。难到多线程的程序,系统调用就不能跟踪?

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
2 [报告]
发表于 2013-05-22 10:42 |只看该作者
top -H找到你想跟踪的线程PID, 然后strace -p那个PID。

论坛徽章:
0
3 [报告]
发表于 2013-05-22 11:44 |只看该作者
linux_c_py_php 发表于 2013-05-22 10:42
top -H找到你想跟踪的线程PID, 然后strace -p那个PID。


top命令显示的进程号啊,不是线程的。

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
4 [报告]
发表于 2013-05-22 12:53 |只看该作者
weichuang02 发表于 2013-05-22 11:44


top命令显示的进程号啊,不是线程的。


看看-H是干嘛的。

论坛徽章:
7
天蝎座
日期:2013-09-28 10:45:42双子座
日期:2013-10-16 16:27:09射手座
日期:2013-10-23 10:21:32处女座
日期:2014-09-17 16:44:332015年亚洲杯之巴林
日期:2015-04-09 17:28:01冥斗士
日期:2015-11-26 16:19:0015-16赛季CBA联赛之山东
日期:2018-03-02 23:59:31
5 [报告]
发表于 2013-05-22 15:18 |只看该作者
方法一:
strace -fp pid , 可以跟踪所有线程, 进程的系统调用。
  1. [root@xxxx]strace -p 24091
  2. Process xxx attached - interrupt to quit
  3. [ Process PID=24091 runs in 32 bit mode. ]
  4. futex(0xc5bbbd8, FUTEX_WAIT, 24215 NULL
复制代码
你的问题不是strace不能跟踪,而是你的线程锁住了。 futex应该是内核里对pthread_mutex_lock实现的一个函数。

方法二(本质同方法一,但更明了):
pstree -p pid 可以查看多线程程序的进程树。
在针对各个线程,逐个的strace -p pid

最后
man pstack
pstack - print a stack trace of a running process
相当于gdb内的bt,打出栈信息。

评分

参与人数 1可用积分 +2 收起 理由
crazyhadoop + 2 赞一个!

查看全部评分

论坛徽章:
6
申猴
日期:2013-10-08 17:32:32金牛座
日期:2013-10-18 19:45:53天秤座
日期:2013-10-18 20:17:34处女座
日期:2014-02-11 10:10:29丑牛
日期:2014-02-15 10:44:15巳蛇
日期:2014-02-18 22:05:54
6 [报告]
发表于 2013-05-28 23:45 |只看该作者
用gdb打断点调试一下,看看各个线程栈信息

论坛徽章:
0
7 [报告]
发表于 2013-05-29 18:29 |只看该作者
cxytz01 发表于 2013-05-22 15:18
方法一:
strace -fp pid , 可以跟踪所有线程, 进程的系统调用。你的问题不是strace不能跟踪,而是你的线程 ...


确实是有一个锁
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP