From ec2e882ca224bfe2153380d3e32a66f712dd7ff0 Mon Sep 17 00:00:00 2001 From: Stephan Fudeus Date: Sat, 23 Dec 2023 14:16:56 +0100 Subject: [PATCH] Fix threading issue in 3.12 by explicitly keeping the main thread alive --- exporter.py | 12 +++--------- 1 file changed, 3 insertions(+), 9 deletions(-) diff --git a/exporter.py b/exporter.py index c533f7e..51ddd43 100755 --- a/exporter.py +++ b/exporter.py @@ -13,7 +13,7 @@ from http.server import HTTPServer from pprint import pformat import requests -from prometheus_client import Gauge, Counter, Enum, MetricsHandler, core, Summary +from prometheus_client import Gauge, Counter, Enum, MetricsHandler, core, Summary, start_http_server class HomematicMetricsProcessor(threading.Thread): @@ -368,14 +368,6 @@ class _ThreadingSimpleServer(ThreadingMixIn, HTTPServer): """Thread per request HTTP server.""" -def start_http_server(port, addr='', registry=core.REGISTRY): - """Starts an HTTP server for prometheus metrics as a daemon thread""" - httpd = _ThreadingSimpleServer((addr, port), MetricsHandler.factory(registry)) - thread = threading.Thread(target=httpd.serve_forever) - thread.daemon = False - thread.start() - - if __name__ == '__main__': PARSER = argparse.ArgumentParser() @@ -418,3 +410,5 @@ def start_http_server(port, addr='', registry=core.REGISTRY): # Start up the server to expose the metrics. logging.info("Exposing metrics on port {}".format(ARGS.port)) start_http_server(int(ARGS.port)) + # Wait until the main loop terminates + PROCESSOR.join()