blob: 7eae4c295a9054659dea16c84e4b122cbbdcb227 [file] [log] [blame]
Benjamin Diazde3d5702018-11-22 17:27:35 -03001# Copyright 2018 Whitestack, LLC
2# *************************************************************
3
4# This file is part of OSM Monitoring module
5# All Rights Reserved to Whitestack, LLC
6
7# Licensed under the Apache License, Version 2.0 (the "License"); you may
8# not use this file except in compliance with the License. You may obtain
9# a copy of the License at
10
11# http://www.apache.org/licenses/LICENSE-2.0
12
13# Unless required by applicable law or agreed to in writing, software
14# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
15# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
16# License for the specific language governing permissions and limitations
17# under the License.
18
19# For those usages not covered by the Apache License, Version 2.0 please
20# contact: bdiaz@whitestack.com or glavado@whitestack.com
21##
Benjamin Diaz5ac7c082019-02-06 11:58:00 -030022import argparse
Benjamin Diazde3d5702018-11-22 17:27:35 -030023import logging
24import subprocess
25import sys
Benjamin Diazde3d5702018-11-22 17:27:35 -030026
27import requests
Benjamin Diazde3d5702018-11-22 17:27:35 -030028
29log = logging.getLogger(__name__)
30
31
32def main():
garciadeblas8e4179f2021-05-14 16:47:03 +020033 parser = argparse.ArgumentParser(prog="osm-mon-healthcheck")
34 parser.add_argument("--config-file", nargs="?", help="MON configuration file")
Benjamin Diazf364b0f2019-07-12 17:10:00 -030035 # args = parser.parse_args()
36 # cfg = Config(args.config_file)
Benjamin Diaz5ac7c082019-02-06 11:58:00 -030037
Benjamin Diazde3d5702018-11-22 17:27:35 -030038 if not _processes_running():
39 sys.exit(1)
Benjamin Diazde3d5702018-11-22 17:27:35 -030040 if not _is_prometheus_exporter_ok():
41 sys.exit(1)
42 sys.exit(0)
43
44
45def _processes_running():
46 def _contains_process(processes, process_name):
47 for row in processes:
48 if process_name in row:
49 return True
50 return False
Benjamin Diaz5ac7c082019-02-06 11:58:00 -030051
garciadeblas8e4179f2021-05-14 16:47:03 +020052 processes_to_check = ["osm-mon-collector", "osm-mon-evaluator", "osm-mon-server"]
53 ps = subprocess.Popen(["ps", "aux"], stdout=subprocess.PIPE).communicate()[0]
54 processes_running = ps.decode().split("\n")
Benjamin Diazde3d5702018-11-22 17:27:35 -030055 for p in processes_to_check:
56 if not _contains_process(processes_running, p):
Benjamin Diazf364b0f2019-07-12 17:10:00 -030057 log.error("Process %s not running!" % p)
Benjamin Diazde3d5702018-11-22 17:27:35 -030058 return False
59 return True
60
61
62def _is_prometheus_exporter_ok():
63 try:
garciadeblas8e4179f2021-05-14 16:47:03 +020064 r = requests.get("http://localhost:8000")
Benjamin Diazde3d5702018-11-22 17:27:35 -030065 r.raise_for_status()
66 return True
67 except Exception:
68 log.exception("MON Prometheus exporter is not running")
69 return False
70
71
garciadeblas8e4179f2021-05-14 16:47:03 +020072if __name__ == "__main__":
Benjamin Diazde3d5702018-11-22 17:27:35 -030073 main()