Python SIGTERM 没有终止子进程

Python SIGTERM not killing subprocess

我有一个 class 可以启动和关闭进程。不过好像没有关闭进程。

我的 python 代码,还有其他方法,但它们工作正常。:

class KismetInstance:
    """Creates a kismet_server instance"""

    def __init__(self, value=False):
        logging.basicConfig(format='%(asctime)-15s::: %(message)s')
        self.logger = logging.getLogger('kismet_instance')
        self.example = value

    def __create_kismet_instance__(self):
        """
        Create a kismet_server subprocess.
        :return:
        """
        shell = ['sudo', '/usr/local/bin/kismet_server']
        self.logger.debug('Attempting to run: %s', " ".join(shell))
        self.kismet = Popen(shell, stdin=PIPE, stdout=PIPE, stderr=PIPE, cwd=r'./logs', preexec_fn=os.setsid)


    def __destroy_kismet_instance__(self):
        """
        Kill the subprocess
        :return:
        """
        os.killpg(os.getpgid(self.kismet.pid), 15)

它可以很好地创建子进程。但是当我尝试 kill (no sudo)

时出现这个错误
OSError: [Errno 1] Operation not permitted

如果我 运行 使用 sudo,过程仍然是 运行ning。

pi@raspberrypi ~/project $ ps -A | grep 'kismet'
 2912 ?        00:00:00 kismet_server

我设法解决了这个问题。事实证明子进程正在重生自己创造了一些奇怪的东西阻止 python 跟踪它。

所以我不得不这样做来修复它,然而这不是最优雅的解决方案,而且相当危险

如果你使用这个要小心,因为如果你输入的术语比我的('kismet')更宽泛,那么你可能会杀死你系统上的很多进程.

def __destroy_kismet_instance__(self):
        """
        Kill the subprocess
        :return:
        """
        sig = signal.SIGKILL # What signal to send
        os.killpg(os.getpgid(self.kismet.pid), sig) # Kill one of them
        p_list = subprocess.Popen(['ps', '-A'], stdout=subprocess.PIPE) # Get All processes on system
        out, err = p_list.communicate()
        for line in out.splitlines(): # For each line (or process)
            if 'kismet' in line: # if 'kismet' appears in its name
                pid = int(line.split(None, 1)[0]) # Get the process ID
                self.logger.debug("Found: %d", pid)
                os.killpg(os.getpgid(pid), sig) # Kill the process