blob: 79ff25be00bb389c4a55878f3677be1352240f04 [file] [log] [blame]
"""
son-emu monitor CLI
(c) 2016 by Manuel Peuster <manuel.peuster@upb.de>
"""
import argparse
import pprint
import zerorpc
import prometheus
pp = pprint.PrettyPrinter(indent=4)
class ZeroRpcClient(object):
def __init__(self):
# network zerorpc
self.c = zerorpc.Client()
# TODO connect to DCNetwork API
#self.c.connect("tcp://127.0.0.1:4242") # TODO hard coded for now. we'll change this later
self.c.connect("tcp://127.0.0.1:5151")
# compute zerorpc
self.compute_api = zerorpc.Client(heartbeat=None, timeout=120) # heartbeat=None, timeout=120
self.compute_api.connect("tcp://127.0.0.1:4242") # TODO hard coded for now. we'll change this later
self.cmds = {}
def execute_command(self, args):
if getattr(self, args["command"]) is not None:
# call the local method with the same name as the command arg
getattr(self, args["command"])(args)
else:
print "Command not implemented."
def setup_metric(self, args):
vnf_name = self._parse_vnf_name(args.get("vnf_name"))
vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
r = self.c.setup_metric(
vnf_name,
vnf_interface,
args.get("metric"))
pp.pprint(r)
def stop_metric(self, args):
vnf_name = self._parse_vnf_name(args.get("vnf_name"))
vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
r = self.c.stop_metric(
vnf_name,
vnf_interface,
args.get("metric"))
pp.pprint(r)
def setup_flow(self, args):
vnf_name = self._parse_vnf_name(args.get("vnf_name"))
vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
r = self.c.setup_flow(
vnf_name,
vnf_interface,
args.get("metric"),
args.get("cookie"))
pp.pprint(r)
def stop_flow(self, args):
vnf_name = self._parse_vnf_name(args.get("vnf_name"))
vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
r = self.c.stop_flow(
vnf_name,
vnf_interface,
args.get("metric"),
args.get("cookie"))
pp.pprint(r)
def prometheus_zrpc(self, args):
vnf_name = self._parse_vnf_name(args.get("vnf_name"))
vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
r = self.c.prometheus(
args.get("datacenter"),
vnf_name,
vnf_interface,
args.get("query"))
pp.pprint(r)
def prometheus(self, args):
vnf_name = self._parse_vnf_name(args.get("vnf_name"))
vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
dc_label = args.get("datacenter")
query = args.get("query")
vnf_status = self.compute_api.compute_status(dc_label, vnf_name)
uuid = vnf_status['id']
query = query.replace('<uuid>', uuid)
r = prometheus.query_Prometheus(query)
pp.pprint(r)
def _parse_vnf_name(self, vnf_name_str):
vnf_name = vnf_name_str.split(':')[0]
return vnf_name
def _parse_vnf_interface(self, vnf_name_str):
try:
vnf_interface = vnf_name_str.split(':')[1]
except:
vnf_interface = None
return vnf_interface
parser = argparse.ArgumentParser(description='son-emu monitor')
parser.add_argument(
"command",
choices=['setup_metric', 'stop_metric', 'setup_flow', 'stop_flow','prometheus'],
help="setup/stop a metric/flow to be monitored or query Prometheus")
parser.add_argument(
"--vnf_name", "-vnf", dest="vnf_name",
help="vnf name:interface to be monitored")
parser.add_argument(
"--metric", "-m", dest="metric",
help="tx_bytes, rx_bytes, tx_packets, rx_packets")
parser.add_argument(
"--cookie", "-c", dest="cookie",
help="flow cookie to monitor")
parser.add_argument(
"--query", "-q", dest="query",
help="prometheus query")
parser.add_argument(
"--datacenter", "-d", dest="datacenter",
help="Data center where the vnf is deployed")
def main(argv):
#print "This is the son-emu monitor CLI."
#print "Arguments: %s" % str(argv)
args = vars(parser.parse_args(argv))
c = ZeroRpcClient()
c.execute_command(args)