我一直有一个问题,我可以杀死产生节点的进程,但节点不会被杀死。有没有人有任何建议我可以做到这一点?子进程杀死子进程但不是子进程的进程
我的一些最新的失败尝试做到这一点是:
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')
至于即时知道,我m基本上被迫使用shell = True,重定向工作 在t中处理孩子的stdout/stderr他父Python进程是不是一种选择,因为我无法在非等待的方式做它找到的功能(和孩子正在运行而父蟒蛇过程中必须做其他事情)
# close nodes
for node in nodes:
node.send_signal(signal.SIGINT)
node.terminate()
这似乎杀死除1个节点以外的所有进程。不总是一样的
尝试添加:''node.wait()'' –
@JamesMills添加node.wait()似乎阻止关机,可能是由于节点仍处于活动状态(因此它只是在等待它们完成) – Calum
如果你不设置'shell = True'会怎么样? – kojiro