我不想花时间搜索我想要附加的进程的PID,所以我做了类似的事情,
gdb -p ($pidof foo)
其中foo是进程名称。
我想知道我是否可以在GDB中这样做。
我正在寻找以下内容。
(gdb) attach $(pidof foo)
Illegal process-id: $(pidof foo).
(gdb) attach `pidof foo`
Illegal process-id: `pidof foo`.
GDB中有这样的东西吗?
答案 0 :(得分:4)
Gdb attach 命令需要将进程ID作为参数。所以,你无法直接实现它。您可以分两步完成:
(gdb) shell pidof foo
12345
(gdb) attach 12345
Attaching to process 12345
...
但是gdb非常灵活,可以extended使用内部脚本(称为Canned Sequences of Commands),python等。这是一个示例脚本,它还可以处理未找到进程或找到多个进程时的情况(首先由pidof给出):
define attach_pidof
if $argc != 1
help attach_pidof
else
shell echo -e "\
set \$PID = "$(echo $(pidof $arg0) 0 | cut -d ' ' -f 1)"\n\
if \$PID > 0\n\
attach "$(pidof -s $arg0)"\n\
else\n\
print \"Process '"$arg0"' not found\"\n\
end" > /tmp/gdb.pidof
source /tmp/gdb.pidof
end
end
document attach_pidof
Attach to process by name.
Usage: attach_pidof PROG_NAME
end
这里我使用了@ dbrank0指出的技巧(回显文件,然后用源代码运行)。此外,我正在使用 echo $(pidof<>)0 在没有找到进程时提供默认值0。
将其放在〜/ .gdbinit 上,这样在gdb start上,此命令将自动添加到gdb中并可以使用:
(gdb) attach_pidof myprog
如果您的gdb支持python扩展,您可以将其放在某个文件中,例如 ext.py :
import gdb
from subprocess import check_output, CalledProcessError
class AttachPidofCommand (gdb.Command):
"Attach to process by name"
def __init__ (self):
super (AttachPidofCommand, self).__init__ ("attach_pidof",
gdb.COMMAND_SUPPORT,
gdb.COMPLETE_NONE, True)
def invoke (self, arg, from_tty):
try:
pid = check_output(["pidof", arg]).split()[0].decode("utf-8")
except CalledProcessError:
gdb.write('process \'%s\' not found\n' % (arg))
return
gdb.write('attach to \'%s\' (%s)\n' % (arg, pid))
gdb.execute('attach %s' % (pid), from_tty)
AttachPidofCommand()
导入并使用相同的方式:
(gdb) source ext.py
(gdb) attach_pidof my_prog