diff options
author | Christian Breunig <christian@breunig.cc> | 2024-01-07 07:11:47 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-01-07 07:11:47 +0100 |
commit | 9b7a96d27653be4a407a63ed42a3fd44b374d81e (patch) | |
tree | bb9acf35aeca2739a767177e714034f1a026192a /python/vyos/utils | |
parent | da65cbfcf8f62885a083608bd2f6fc146bea42af (diff) | |
parent | ad9bdfc248cf47b3361bd0e5d7371d56131160a0 (diff) | |
download | vyos-1x-9b7a96d27653be4a407a63ed42a3fd44b374d81e.tar.gz vyos-1x-9b7a96d27653be4a407a63ed42a3fd44b374d81e.zip |
Merge pull request #2764 from c-po/T5195-process
T5195: add timeout argument to process_named_running()
Diffstat (limited to 'python/vyos/utils')
-rw-r--r-- | python/vyos/utils/process.py | 27 |
1 files changed, 21 insertions, 6 deletions
diff --git a/python/vyos/utils/process.py b/python/vyos/utils/process.py index e09c7d86d..cd58b4be2 100644 --- a/python/vyos/utils/process.py +++ b/python/vyos/utils/process.py @@ -204,17 +204,32 @@ def process_running(pid_file): pid = f.read().strip() return pid_exists(int(pid)) -def process_named_running(name, cmdline: str=None): +def process_named_running(name, cmdline: str=None, timeout=0): """ Checks if process with given name is running and returns its PID. If Process is not running, return None """ from psutil import process_iter - for p in process_iter(['name', 'pid', 'cmdline']): - if cmdline: - if p.info['name'] == name and cmdline in p.info['cmdline']: + def check_process(name, cmdline): + for p in process_iter(['name', 'pid', 'cmdline']): + if cmdline: + if name in p.info['name'] and cmdline in p.info['cmdline']: + return p.info['pid'] + elif name in p.info['name']: return p.info['pid'] - elif p.info['name'] == name: - return p.info['pid'] + return None + if timeout: + import time + time_expire = time.time() + timeout + while True: + tmp = check_process(name, cmdline) + if not tmp: + if time.time() > time_expire: + break + time.sleep(0.100) # wait 250ms + continue + return tmp + else: + return check_process(name, cmdline) return None def is_systemd_service_active(service): |