我有一个脚本,它应该(除其他外)打开一个新的终端窗口并在该终端中运行TCPDUMP。然后,脚本等待用户在原始窗口中发出完成的信号(提示等待“y”)。当用户输入“y”时,我需要终止TCPDUMP终端窗口。设置如下:

tcp_dump_line = "\"/usr/sbin/tcpdump -nn -tttt -i " + nic
tcp_dump_line += " 'not (host ::1 and tcp and port 5432) and not (host ::1"
tcp_dump_line += " and udp and port 44954) and not (host ::1 and tcp and "
tcp_dump_line += "port 4101) and not (host 127.0.0.1 and tcp and "
tcp_dump_line += "port 4101)'\""
command = ['xfce4-terminal', '-e', tcp_dump_line,
          '-T', 'TCPDUMP']
print "[*] tcpdump command: " + ' '.join(command)

proc1 = subprocess.Popen(' '.join(command), shell=True)
running_procs.append(proc1)

一切都会好起来的。在程序退出时,我运行:
def kill_procs(running_procs):
    '''Kill processes spawned by this scripts.'''
    print "[*] Killing all startop spawned processes"
    for p in running_procs:
        print "[+] Killing PID: " + str(p.pid)
        p.kill()

这适用于我生成的其他进程,但这些进程是直接程序,而不是新终端。从跟踪PIDs可以得到的信息来看,新终端是由运行Python脚本的终端的PID生成的,而不是Python实例本身的PID。因此,在打开新的终端窗口后,写入running_procs的PID似乎消失了,因此无法杀死生成的终端。
知道如何退出生成的终端/命令吗?我也试过没有运气的。

最佳答案

最终更容易使用OS命令来解决这个问题。因为新终端的标题被设置为TCPDUMP我就可以使用pidof来获取它。

tcpdump_pids = subprocess.check_output(['pidof', 'tcpdump']).split()
for pid in tcpdump_pids:
    print "[+] Killing PID: " + pid
    os.kill(int(pid), signal.SIGKILL)

10-08 18:59