我遇到了一个问题,即我可以杀死产生节点的进程,但节点不会被杀死。有没有人建议我怎么做?
我最近尝试完成的一些失败尝试是:
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个节点之外的所有进程。并不总是相同的
答案 0 :(得分:2)
您可以尝试使用os.killpg
。此函数将信号发送到进程组,如果您的进程不更改进程组,它应该有效。
import os
import signal
os.killpg(os.getpgid(pid), signal.SIGINT)
注意,如果要在shell(bash,zsh等)下创建进程,那么进程组将被更改,在这种情况下应该使用更复杂的技术。