Drgn
DRGN是一个相对较新的查看内核状态的工具。它是Meta开发的,作为crash的一个替代工具。
准备环境
安装
参考最新的安装文档。
有几种安装的方式,感觉通过pip来安装,方式比较统一。
sudo pip3 install drgn如果能运行下面的命令,看上去应该是安装好了。
python3 -m drgn --help内核调试信息
在使用drgn调试内核前,先要保证对应的调试信息在。如果在运行drgn时看到没有调试信息的提示,可以参考Getting Debug Symbols来处理。
其中包括了自己编译的内核,和使用发行版自带的内核两种情况。
内核调试helper
为了方便调试内核,drgn项目已经给我们提供了不少helper来帮助我们。
其中有专门一节是讲述内核数据结构相关的helper。
使用
简单的例子
下面是一个非常简单的例子,当我们准备好环境后,可以通过drgn来查看某个进程的命令行名字。
实际上,我已经知道了这个程序的pid,所以说这个例子就是个例子。。。
Last updated