blob: 99ec1d3f2f015a443590c642eda7b6597af69231 [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():
Benjamin Diaz5ac7c082019-02-06 11:58:00 -030033 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
Benjamin Diazde3d5702018-11-22 17:27:35 -030052 processes_to_check = ['osm-mon-collector', 'osm-mon-evaluator', 'osm-mon-server']
53 ps = subprocess.Popen(['ps', 'aux'], stdout=subprocess.PIPE).communicate()[0]
Benjamin Diaz274a6e92018-11-26 13:14:33 -030054 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:
64 r = requests.get('http://localhost:8000')
65 r.raise_for_status()
66 return True
67 except Exception:
68 log.exception("MON Prometheus exporter is not running")
69 return False
70
71
Benjamin Diazde3d5702018-11-22 17:27:35 -030072if __name__ == '__main__':
73 main()