3

我想为 gdb 编写一个脚本,它将backtrace每 10 毫秒保存(堆栈)进程。我怎样才能做到这一点?

它可以像“身无分文”的调用图分析(对于不能使用任何高级分析器的人)。

是的,有很多高级分析器。适用于流行的 CPU 和流行的操作系统。Shark 非常令人印象深刻且易于使用,但我想使用此类脚本获得基本功能,与 gdb 一起使用。

4

3 回答 3

3

你能得到lsstack吗?也许您可以从应用程序外部的脚本运行它。为什么是 10 毫秒?在 100 毫秒或更长时间时,百分比将大致相同。如果应用程序太快,您可以通过外部循环人为地减慢它,这也不会改变百分比。就此而言,如果应用程序运行时间足够长并且您的目标是找出性能问题所在,您可以使用 Ctrl-C 在 gdb 下手动获取示例。

于 2010-03-25T14:51:25.927 回答
1

(1) 手册。在 shell 中执行以下操作。在 shell 提示符下重复按 Ctrl+C。

gdb -x print_callstack.gdb -p pid

或者,(2)在另一个shell上重复向pid发送信号的次数与下面的循环相同

let count=0; \
while [ $count -le 100 ]; do \
  kill -INT pid ; sleep 0.10; \
  let $count=$count+1; \
done

from (1)的来源print_callstack.gdb如下:

set pagination 0
set $count = 0
while $count < 100
    backtrace
    continue
    set $count = $count + 1
end
detach
quit

pstack 手册页https://linux.die.net/man/1/pstack

于 2015-11-18T16:51:57.450 回答
0
cat > gdb.run
set pagination 0 
backtrace 
continue 
backtrace 
continue 
... as many more backtrace + continue's as needed
backtrace 
continue 
detach 
quit

当然,省略重复的换行符,这个论坛软件中的单个换行符是怎么做的呢?:(

gdb -x gdb.run -p $pid

然后只需使用 do

kill -INT $pid ; sleep 0.01

在另一个脚本的循环中。

kill -INT是你点击时操作系统所做的事情ctrl-C。读者练习:使 gdb 脚本使用具有 $n 次迭代的循环。

于 2010-06-02T09:14:30.457 回答