diff options
author | Devaev Maxim <[email protected]> | 2019-10-12 00:00:40 +0300 |
---|---|---|
committer | Devaev Maxim <[email protected]> | 2019-10-12 00:00:40 +0300 |
commit | 35a40614e5be2e57f29e930ad31ee41a36d8bb03 (patch) | |
tree | 6f398a23fb4a87bb981d5674a6ca778e433a86a3 /kvmd | |
parent | 74449c81ad6e6d5bb170b3113b6112fb91f6f445 (diff) |
use process_name_prefix to kill ustreamer
Diffstat (limited to 'kvmd')
-rw-r--r-- | kvmd/apps/cleanup/__init__.py | 27 |
1 files changed, 14 insertions, 13 deletions
diff --git a/kvmd/apps/cleanup/__init__.py b/kvmd/apps/cleanup/__init__.py index 3314066c..57823ff1 100644 --- a/kvmd/apps/cleanup/__init__.py +++ b/kvmd/apps/cleanup/__init__.py @@ -72,22 +72,23 @@ def _clear_gpio(config: Section) -> None: def _kill_streamer(config: Section) -> None: logger = get_logger(0) - streamer = os.path.basename(config.streamer.cmd[0]) + if config.streamer.process_name_prefix: + prefix = config.streamer.process_name_prefix + ":" + logger.info("Trying to find and kill the streamer %r ...", prefix + " <app>") - logger.info("Trying to find and kill %r ...", streamer) - for proc in psutil.process_iter(): - attrs = proc.as_dict(attrs=["name"]) - if os.path.basename(attrs.get("name", "")) == streamer: - try: - proc.send_signal(signal.SIGTERM) - except Exception: - logger.exception("Can't send SIGTERM to streamer with pid=%d", proc.pid) - time.sleep(3) - if proc.is_running(): + for proc in psutil.process_iter(): + attrs = proc.as_dict(attrs=["name"]) + if attrs.get("name", "").startswith(prefix): try: - proc.send_signal(signal.SIGKILL) + proc.send_signal(signal.SIGTERM) except Exception: - logger.exception("Can't send SIGKILL to streamer with pid=%d", proc.pid) + logger.exception("Can't send SIGTERM to streamer with pid=%d", proc.pid) + time.sleep(3) + if proc.is_running(): + try: + proc.send_signal(signal.SIGKILL) + except Exception: + logger.exception("Can't send SIGKILL to streamer with pid=%d", proc.pid) def _remove_sockets(config: Section) -> None: |