可能可行的基本方法是为要调试的程序设置信号处理程序以加载到调试器中。然后向进程发送一个调试信号(通过kill 命令),您就可以远程附加。
您可以通过python trepan debuggers 执行此操作
import signal
def signal_handler(num, f):
from trepan.interfaces import server as Mserver
from trepan.api import debug
connection_opts={'IO': 'TCP', 'PORT': 1955}
intf = Mserver.ServerInterface(connection_opts=connection_opts)
dbg_opts = {'interface': intf}
print('Starting TCP server listening on port 1955.')
debug(dbg_opts=dbg_opts)
return
signal.signal(signal.SIGUSR1, signal_handler)
# Go about your business...
import time
import os
print(os.getpid())
for i in range(10000):
time.sleep(0.2)
现在运行:
$ python /tmp/foo.py
8530
从上面的输出中,我们列出了我们要调试的 Python 进程的 pid。
现在在 shell 中,我们发送一个信号来告诉进程进入在信号处理程序中设置的调试器。您将不得不调整
进程 ID。
$ kill -USR1 8530 # Adjust the pid to what you see above
在我们运行 /tmp/foo.py 的 shell 中,您现在应该看到
新输出:
$ python /tmp/foo.py
8530
Starting TCP server listening on port 1955. # This is new
回到我们发出kill -USR1 的shell,我们现在将已停止的进程附加到调试器中:
$ trepan2 --client --port 1955
Connected.
(/tmp/foo.py:11 @101): signal_handler
-- 11 return
(trepan2*) list
6 connection_opts={'IO': 'TCP', 'PORT': 1955}
7 intf = Mserver.ServerInterface(connection_opts=connection_opts)
8 dbg_opts = {'interface': intf}
9 print('Starting TCP server listening on port 1955.')
10 debug(dbg_opts=dbg_opts)
11 -> return
12
13 signal.signal(signal.SIGUSR1, signal_handler)
14 # Go about your business...
(trepan2*) backtrace
-> 0 signal_handler(num=10, f=<frame object at 0x7f9036796050>)
called from file '/tmp/foo.py' at line 11
## 1 <module> file '/tmp/foo.py' at line 20