run: track pids.

This commit is contained in:
tecnovert 2019-07-25 15:28:44 +02:00
parent 867fbf0d09
commit b365814cb5
No known key found for this signature in database
GPG Key ID: 8ED6D8750C4E3F93

View File

@ -50,9 +50,10 @@ def startDaemon(node_dir, bin_dir, daemon_bin, opts=[]):
return subprocess.Popen(args, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE) return subprocess.Popen(args, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
def runClient(fp, dataDir, chain): def runClient(fp, data_dir, chain):
global swap_client global swap_client
settings_path = os.path.join(dataDir, 'basicswap.json') settings_path = os.path.join(data_dir, 'basicswap.json')
pids_path = os.path.join(data_dir, '.pids')
if not os.path.exists(settings_path): if not os.path.exists(settings_path):
raise ValueError('Settings file not found: ' + str(settings_path)) raise ValueError('Settings file not found: ' + str(settings_path))
@ -61,6 +62,13 @@ def runClient(fp, dataDir, chain):
settings = json.load(fs) settings = json.load(fs)
daemons = [] daemons = []
pids = []
if os.path.exists(pids_path):
with open(pids_path) as fd:
for ln in fd:
# TODO: try close
logger.warning('Found pid for daemon {} '.format(ln.strip()))
for c, v in settings['chainclients'].items(): for c, v in settings['chainclients'].items():
if v['manage_daemon'] is True: if v['manage_daemon'] is True:
@ -68,9 +76,16 @@ def runClient(fp, dataDir, chain):
filename = c + 'd' + ('.exe' if os.name == 'nt' else '') filename = c + 'd' + ('.exe' if os.name == 'nt' else '')
daemons.append(startDaemon(v['datadir'], v['bindir'], filename)) daemons.append(startDaemon(v['datadir'], v['bindir'], filename))
logger.info('Started {} {}'.format(filename, daemons[-1].pid)) pid = daemons[-1].pid
pids.append((c, pid))
logger.info('Started {} {}'.format(filename, pid))
swap_client = BasicSwap(fp, dataDir, settings, chain) if len(pids) > 0:
with open(pids_path, 'w') as fd:
for p in pids:
fd.write('{}:{}\n'.format(*p))
swap_client = BasicSwap(fp, data_dir, settings, chain)
signal.signal(signal.SIGINT, signal_handler) signal.signal(signal.SIGINT, signal_handler)
signal.signal(signal.SIGTERM, signal_handler) signal.signal(signal.SIGTERM, signal_handler)
@ -97,16 +112,35 @@ def runClient(fp, dataDir, chain):
t.stop() t.stop()
t.join() t.join()
closed_pids = []
for d in daemons: for d in daemons:
logger.info('Terminating {}'.format(d.pid)) int_pid = d.pid
d.terminate() logger.info('Terminating {}'.format(int_pid))
d.wait(timeout=120) try:
if d.stdout: d.terminate()
d.stdout.close() d.wait(timeout=120)
if d.stderr: if d.stdout:
d.stderr.close() d.stdout.close()
if d.stdin: if d.stderr:
d.stdin.close() d.stderr.close()
if d.stdin:
d.stdin.close()
closed_pids.append(int_pid)
except Exception as ex:
logger.error('Error: {}'.format(ex))
if os.path.exists(pids_path):
with open(pids_path) as fd:
lines = fd.read().split('\n')
still_running = ''
for ln in lines:
try:
if not int(ln.split(':')[1]) in closed_pids:
still_running += ln + '\n'
except Exception:
pass
with open(pids_path, 'w') as fd:
fd.write(still_running)
def printVersion(): def printVersion():