Add collectd monitoring script
This commit is contained in:
parent
395812c0f8
commit
6fb5a751c6
60
packages/collectd/pybitmessagestatus.py
Normal file
60
packages/collectd/pybitmessagestatus.py
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
#!/usr/bin/env python2.7
|
||||||
|
|
||||||
|
import collectd
|
||||||
|
import json
|
||||||
|
import xmlrpclib
|
||||||
|
|
||||||
|
pybmurl = ""
|
||||||
|
api = ""
|
||||||
|
|
||||||
|
def init_callback():
|
||||||
|
global api
|
||||||
|
api = xmlrpclib.ServerProxy(pybmurl)
|
||||||
|
collectd.info('pybitmessagestatus.py init done')
|
||||||
|
|
||||||
|
def config_callback(ObjConfiguration):
|
||||||
|
global pybmurl
|
||||||
|
apiUsername = ""
|
||||||
|
apiPassword = ""
|
||||||
|
apiInterface = "127.0.0.1"
|
||||||
|
apiPort = 8445
|
||||||
|
for node in ObjConfiguration.children:
|
||||||
|
key = node.key.lower()
|
||||||
|
if key.lower() == "apiusername" and node.values:
|
||||||
|
apiUsername = node.values[0]
|
||||||
|
elif key.lower() == "apipassword" and node.values:
|
||||||
|
apiPassword = node.values[0]
|
||||||
|
elif key.lower() == "apiinterface" and node.values:
|
||||||
|
apiInterface = node.values[0]
|
||||||
|
elif key.lower() == "apiport" and node.values:
|
||||||
|
apiPort = node.values[0]
|
||||||
|
pybmurl = "http://" + apiUsername + ":" + apiPassword + "@" + apiInterface+ ":" + str(int(apiPort)) + "/"
|
||||||
|
collectd.info('pybitmessagestatus.py config done')
|
||||||
|
|
||||||
|
def read_callback():
|
||||||
|
try:
|
||||||
|
clientStatus = json.loads(api.clientStatus())
|
||||||
|
except:
|
||||||
|
collectd.info("Exception loading or parsing JSON")
|
||||||
|
return
|
||||||
|
|
||||||
|
for i in ["networkConnections", "numberOfPubkeysProcessed", "numberOfMessagesProcessed", "numberOfBroadcastsProcessed"]:
|
||||||
|
metric = collectd.Values()
|
||||||
|
metric.plugin = "pybitmessagestatus"
|
||||||
|
if i[0:6] == "number":
|
||||||
|
metric.type = 'counter'
|
||||||
|
else:
|
||||||
|
metric.type = 'gauge'
|
||||||
|
metric.type_instance = i.lower()
|
||||||
|
try:
|
||||||
|
metric.values = [clientStatus[i]]
|
||||||
|
except:
|
||||||
|
collectd.info("Value for %s missing" % (i))
|
||||||
|
metric.dispatch()
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
|
else:
|
||||||
|
collectd.register_init(init_callback)
|
||||||
|
collectd.register_config(config_callback)
|
||||||
|
collectd.register_read(read_callback)
|
Loading…
Reference in New Issue
Block a user