From 482438c7d5522617dc3cfedf0a550610a9418e49 Mon Sep 17 00:00:00 2001 From: PhiBo Date: Wed, 11 Dec 2024 08:18:41 +0100 Subject: [PATCH] src - Handle closed connection - Reconnect if 'Connection unexpectedly closed' exception has been raised --- routeros_log_exporter/fetcher.py | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/routeros_log_exporter/fetcher.py b/routeros_log_exporter/fetcher.py index f13065d..a830eea 100644 --- a/routeros_log_exporter/fetcher.py +++ b/routeros_log_exporter/fetcher.py @@ -69,6 +69,7 @@ from queue import Queue from librouteros import connect +from librouteros.exceptions import ConnectionClosed from .exception import ConfigError from .output import Output @@ -191,12 +192,16 @@ def _process_messages(self): "follow-only": "", } ) - for message in log_stream: - if self._should_terminate: - return - if message.get(".dead") is True: - continue - self._message_queue.put(LogMessage(fetcher=self, message=message)) + try: + for message in log_stream: + if self._should_terminate: + return + if message.get(".dead") is True: + continue + self._message_queue.put(LogMessage(fetcher=self, message=message)) + except ConnectionClosed as e: + logger.error(f"Connection to device '{self.hostname}' closed: {str(e)}") + self.disconnect() @property def api(self) -> RouterOSApi: @@ -229,6 +234,12 @@ def api(self) -> RouterOSApi: logger.info("Connected") return self._api + def disconnect(self): + if not self._api: + return + self._api.close() + self._api = None + def handle_signal(self, signal_number): pass