srs.py调试脚本介绍—SRS对StateThreads的改进与完善

前面《如何查看协程相关信息》,已经介绍了如何查看协程数量,遍历协程,通过 EBP 寄存器去查看协程的函数调用层级。不过这样手敲命令,还是比较麻烦。有没一种更自动化一点的方法呢?

答:有,就是 srs.py 脚本,这是一个 python 写的脚本,主要是调 GDB 的 API 完成一些功能,所以这个脚本只能在 GDB 窗口里运行,千万不要用 python 命令直接运行这个脚本,没用的。

我们把 srs.py 脚本下载下来,然后放到 st-1.9 目录里,如下:

1-1

然后我们就能在 clion 的 GDB 窗口用 source 命令导入这个 srs.py 脚本,如下:

source srs.py

1-2

当 srs.py 脚本 导入之后,就给 gdb 创建了两个新的命令,nn_coroutines 与 show_coroutines

1,nn_coroutines 打印协程的地址以及总数量

nn_coroutines 命令是打印协程的地址以及总数量,因为协程可能很多,所以默认是相隔 1000 条才打印一次 协程地址,所以如果你有 2000 个协程,他默认只会打印第 1 个,第 1000 个,第 2000 个 协程的地址。

如果你希望全部打印,可以给 nn_coroutines 传参数 1,这个参数如果不传,默认是 1000

nn_coroutines 1

1-3

其实他这里打印的不是 协程本身的地址,而是里面的 tlink 字段的地址。你可以用《如何查看协程相关信息》介绍的方法,修改 srs.py,用偏移获取到 协程的地址再打印。


2,show_coroutines 显示协程的函数调用

1-4

show_coroutines 命令只显示了倒数第二层的函数调用,如下:

1-5

这个命令我觉得还可以继续优化一下,因为大部分的协程,他肯定是阻塞在切换协程哪里的函数的,所以看起来几乎是一样的,通过地址看不出来这是什么协程。

我个人觉得最好显示倒数 3 层的函数出来,会更容易阅读一些。读者可以自行修改 srs.py 来实现这个功能。


参考资料:

1,https://github.com/ossrs/state-threads/issues/15


 本文是《SRS原理》一书中的文章,如需观看更多内容,请购买本书。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Loken2020

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值