子进程会杀死子进程,但不会杀死子进程产生的进程

时间:2014-01-13 02:05:27

标签: python subprocess selenium-grid

我遇到了一个问题,即我可以杀死产生节点的进程,但节点不会被杀死。有没有人建议我怎么做?

我最近尝试完成的一些失败尝试是:

node.terminate()

node.send_signal(signal.SIGINT)

下面是代码:

from subprocess import Popen
import json
import sys
import os
import signal
import requests

FNULL = open(os.devnull, 'w')

json_data = open('nodes.json', 'r').read()
data = json.loads(json_data)

port = data['port']

# launch hub
hub = Popen('java -jar selenium-server-standalone-2.37.0.jar -role hub -port %s' % port, stdout=FNULL, stderr=FNULL, shell=True)

#launch nodes
nodes = []
for node in data['nodes']:
    options = ''
    if node['name'] == 'CHROME':
        options += '-Dwebdriver.chrome.driver=../grid/chromedriver '
    #options += ' -browser browserName='+node['name']+' maxInstances='+str(node['maxInstances'])
    nodes.append(Popen('java -jar selenium-server-standalone-2.37.0.jar -role node -hub http://localhost:%i/grid/register %s' % (port, options), stdout=FNULL, stderr=FNULL, shell=True))

# wait for user input
print "type 'q' and ENTER to close the grid:"
while True:
    line = sys.stdin.readline()
    if line == 'q\n':
        break

# close nodes
for node in nodes:
    #node.terminate()
    node.send_signal(signal.SIGINT)

# close hub   
r = requests.get('http://localhost:'+str(port)+'/lifecycle-manager?action=shutdown')

据我所知,我基本上被迫使用shell = True来重定向工作 在父python进程中处理子进程的stdout / stderr不是一个选项,因为我找不到以非等待方式执行它的功能(并且父进程必须在子进程运行时执行其他操作)

# close nodes
for node in nodes:
    node.send_signal(signal.SIGINT)
    node.terminate()    

这似乎会杀死除1个节点之外的所有进程。并不总是相同的

1 个答案:

答案 0 :(得分:2)

您可以尝试使用os.killpg。此函数将信号发送到进程组,如果您的进程不更改进程组,它应该有效。

import os
import signal

os.killpg(os.getpgid(pid), signal.SIGINT)

注意,如果要在shell(bash,zsh等)下创建进程,那么进程组将被更改,在这种情况下应该使用更复杂的技术。