ansible/roles/nagios_client/files/scripts/check_fedmsg_consumer_backlog.py
Jiri Podivin f513e7cbcd Linting python scripts
Signed-off-by: Jiri Podivin <jpodivin@redhat.com>
2024-09-18 19:57:29 +00:00

72 lines
2.4 KiB
Python

#!/usr/bin/python
import json
import os
import sys
import zmq
try:
service = sys.argv[1]
check_consumer = sys.argv[2]
backlog_warning = int(sys.argv[3])
backlog_critical = int(sys.argv[4])
if os.path.exists('/var/run/fedmsg/monitoring-%s.socket' % service):
fname = '/var/run/fedmsg/monitoring-%s.socket' % service
elif os.path.exists('/var/run/fedmsg/monitoring-%s-.socket' % service):
fname = '/var/run/fedmsg/monitoring-%s-.socket' % service
elif os.path.exists('/var/run/fedmsg/monitoring-%s-3.socket' % service):
fname = '/var/run/fedmsg/monitoring-%s-3.socket' % service
else:
print("UNKNOWN - socket file does not exists")
sys.exit(3)
if not os.path.exists(fname):
print("UNKNOWN - %s does not exist" % fname)
sys.exit(3)
if not os.access(fname, os.W_OK):
print("UNKNOWN - cannot write to %s" % fname)
sys.exit(3)
connect_to = "ipc:///%s" % fname
ctx = zmq.Context()
s = ctx.socket(zmq.SUB)
s.connect(connect_to)
try:
s.setsockopt(zmq.SUBSCRIBE, '')
except TypeError:
s.setsockopt_string(zmq.SUBSCRIBE, '')
poller = zmq.Poller()
poller.register(s, zmq.POLLIN)
timeout = 20000
events = dict(poller.poll(timeout))
if s in events and events[s] == zmq.POLLIN:
msg = s.recv()
msg = json.loads(msg)
else:
print('UNKNOWN - ZMQ timeout. No message received in %i ms' % timeout)
sys.exit(3)
for consumer in msg['consumers']:
if consumer['name'] == check_consumer:
if consumer['backlog'] is None:
print('ERROR: fedmsg consumer %s is not initialized' % consumer['name'])
sys.exit(3)
elif consumer['backlog'] > backlog_critical:
print('CRITICAL: fedmsg consumer %s backlog value is %i' % (consumer['name'],consumer['backlog']))
sys.exit(2)
elif consumer['backlog'] > backlog_warning:
print('WARNING: fedmsg consumer %s backlog value is %i' % (consumer['name'],consumer['backlog']))
sys.exit(1)
else:
print('OK: fedmsg consumer %s backlog value is %i' % (consumer['name'],consumer['backlog']))
sys.exit(0)
print("UNKNOWN: fedmsg consumer %s not found" % check_consumer)
sys.exit(3)
except Exception as err:
print("UNKNOWN:", str(err))
sys.exit(3)