Total Complexity | 0 |
Total Lines | 44 |
Duplicated Lines | 0 % |
Changes | 0 |
1 | import asyncio |
||
2 | import logging |
||
3 | import sys |
||
4 | |||
5 | from prometheus_client.core import REGISTRY |
||
6 | from prometheus_client.exposition import start_http_server |
||
7 | |||
8 | from .config import Config |
||
9 | from .kibana_collector import KibanaCollector |
||
10 | |||
11 | logger = logging.getLogger(__name__) |
||
12 | |||
13 | try: |
||
14 | config = Config() |
||
15 | except ValueError as e: |
||
16 | logger.critical(e) |
||
17 | logger.critical("Invalid configuration. Exiting.") |
||
18 | sys.exit(1) |
||
19 | |||
20 | |||
21 | logger.info("Starting Kibana Prometheus exporter version %s\n" % config.version + config.description()) |
||
22 | |||
23 | REGISTRY.register( |
||
24 | KibanaCollector( |
||
25 | config.kibana_url, |
||
26 | kibana_login=config.kibana_login, |
||
27 | kibana_password=config.kibana_password, |
||
28 | ignore_ssl=config.ignore_ssl, |
||
29 | ) |
||
30 | ) |
||
31 | |||
32 | try: |
||
33 | start_http_server(config.listen_port) |
||
34 | except PermissionError as e: |
||
35 | logger.critical("Cannot bind to port %s. Permission denied.", config.listen_port) |
||
36 | sys.exit(2) |
||
37 | |||
38 | loop = asyncio.new_event_loop() |
||
39 | try: |
||
40 | loop.run_forever() |
||
41 | except KeyboardInterrupt: |
||
42 | loop.stop() |
||
43 | loop.close() |
||
44 |