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

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

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

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

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

bash 复制代码
source srs.py

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

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

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

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

复制代码
nn_coroutines 1

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


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

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

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

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


参考资料:

1,github.com/ossrs/state...


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

相关推荐
政采云技术2 天前
音视频通用组件设计探索和应用
前端·音视频开发
Android疑难杂症4 天前
鸿蒙Media Kit媒体服务开发快速指南
android·harmonyos·音视频开发
mortimer4 天前
一键实现人声伴奏分离:基于 `uv`, `FFmpeg` 和 `audio-separator` 的高效解决方案
python·ffmpeg·音视频开发
音视频牛哥5 天前
全面解读Android平台GB28181接入方案:SmartGBD的技术实现与应用
音视频开发·视频编码·直播
音视频牛哥5 天前
RTSP|RTMP|GB28181深度解读:如何构建系统级实时视频链路
音视频开发·视频编码·直播
音视频牛哥6 天前
SmartMediaKit:如何让智能系统早人一步“跟上现实”的时间架构--从实时流媒体到系统智能的演进
人工智能·计算机视觉·音视频·音视频开发·具身智能·十五五规划具身智能·smartmediakit
快乐1016 天前
Media3 ExoPlayer有声音无画面分析
音视频开发
mortimer7 天前
视频翻译中的最后一公里:口型匹配为何如此难
openai·音视频开发·视频编码
mortimer9 天前
搞懂FFmpeg中2个桀骜不驯的参数:CRF 与 Preset
ffmpeg·音视频开发·视频编码
mortimer11 天前
FFmpeg 拼接视频-记录我踩过的坑
ffmpeg·音视频开发