blob: 20bfc25cbe32c6ceb8257c93a308adfc1e8a2425 [file] [log] [blame]
stevenvanrossemc5a536a2016-02-16 14:52:39 +01001"""
stevenvanrossemadfd06f2016-04-22 10:39:08 +02002son-emu monitor CLI
stevenvanrossemc5a536a2016-02-16 14:52:39 +01003(c) 2016 by Manuel Peuster <manuel.peuster@upb.de>
stevenvanrossem1a6843a2016-05-19 12:19:36 +02004Steven Van Rossem <steven.vanrossem@intec.ugent.be>
stevenvanrossemc5a536a2016-02-16 14:52:39 +01005"""
6
7import argparse
8import pprint
stevenvanrossemc5a536a2016-02-16 14:52:39 +01009import zerorpc
stevenvanrossem1a6843a2016-05-19 12:19:36 +020010from emuvim.cli import prometheus
stevenvanrossemc5a536a2016-02-16 14:52:39 +010011
12pp = pprint.PrettyPrinter(indent=4)
13
14class ZeroRpcClient(object):
15
16 def __init__(self):
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020017 # network zerorpc
stevenvanrossemc5a536a2016-02-16 14:52:39 +010018 self.c = zerorpc.Client()
19 # TODO connect to DCNetwork API
20 #self.c.connect("tcp://127.0.0.1:4242") # TODO hard coded for now. we'll change this later
21 self.c.connect("tcp://127.0.0.1:5151")
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020022
23 # compute zerorpc
24 self.compute_api = zerorpc.Client(heartbeat=None, timeout=120) # heartbeat=None, timeout=120
25 self.compute_api.connect("tcp://127.0.0.1:4242") # TODO hard coded for now. we'll change this later
26
stevenvanrossemc5a536a2016-02-16 14:52:39 +010027 self.cmds = {}
28
29 def execute_command(self, args):
30 if getattr(self, args["command"]) is not None:
31 # call the local method with the same name as the command arg
32 getattr(self, args["command"])(args)
33 else:
stevenvanrossem49378152016-05-19 11:33:48 +020034 print("Command not implemented.")
stevenvanrossemc5a536a2016-02-16 14:52:39 +010035
stevenvanrossema24b4372016-04-14 09:55:20 +020036 def setup_metric(self, args):
stevenvanrossemed711fd2016-04-11 16:59:29 +020037 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
38 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
stevenvanrossema24b4372016-04-14 09:55:20 +020039 r = self.c.setup_metric(
40 vnf_name,
41 vnf_interface,
42 args.get("metric"))
43 pp.pprint(r)
stevenvanrossemb098cb52016-04-15 13:28:23 +020044
stevenvanrossembbdb5ee2016-04-15 15:18:44 +020045 def stop_metric(self, args):
stevenvanrossemb098cb52016-04-15 13:28:23 +020046 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
47 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
stevenvanrossem300e1e52016-04-22 22:17:51 +020048 r = self.c.stop_metric(
stevenvanrossemed711fd2016-04-11 16:59:29 +020049 vnf_name,
50 vnf_interface,
stevenvanrossemed711fd2016-04-11 16:59:29 +020051 args.get("metric"))
stevenvanrossemb098cb52016-04-15 13:28:23 +020052 pp.pprint(r)
stevenvanrossemc5a536a2016-02-16 14:52:39 +010053
stevenvanrossem461941c2016-05-10 11:41:29 +020054 def setup_flow(self, args):
55 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
56 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
57 r = self.c.setup_flow(
58 vnf_name,
59 vnf_interface,
60 args.get("metric"),
61 args.get("cookie"))
62 pp.pprint(r)
63
stevenvanrossem81955a52016-05-12 14:34:12 +020064 def stop_flow(self, args):
65 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
66 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
67 r = self.c.stop_flow(
68 vnf_name,
69 vnf_interface,
70 args.get("metric"),
71 args.get("cookie"))
72 pp.pprint(r)
73
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020074 def prometheus_zrpc(self, args):
stevenvanrossem461941c2016-05-10 11:41:29 +020075 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
76 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
77 r = self.c.prometheus(
78 args.get("datacenter"),
79 vnf_name,
80 vnf_interface,
81 args.get("query"))
82 pp.pprint(r)
83
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020084 def prometheus(self, args):
85 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
86 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
87 dc_label = args.get("datacenter")
88 query = args.get("query")
89 vnf_status = self.compute_api.compute_status(dc_label, vnf_name)
90 uuid = vnf_status['id']
91 query = query.replace('<uuid>', uuid)
92
93 r = prometheus.query_Prometheus(query)
94 pp.pprint(r)
95
stevenvanrossem461941c2016-05-10 11:41:29 +020096
stevenvanrossemed711fd2016-04-11 16:59:29 +020097 def _parse_vnf_name(self, vnf_name_str):
98 vnf_name = vnf_name_str.split(':')[0]
99 return vnf_name
100
101 def _parse_vnf_interface(self, vnf_name_str):
102 try:
103 vnf_interface = vnf_name_str.split(':')[1]
104 except:
105 vnf_interface = None
106
107 return vnf_interface
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100108
stevenvanrossem461941c2016-05-10 11:41:29 +0200109parser = argparse.ArgumentParser(description='son-emu monitor')
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100110parser.add_argument(
111 "command",
stevenvanrossem81955a52016-05-12 14:34:12 +0200112 choices=['setup_metric', 'stop_metric', 'setup_flow', 'stop_flow','prometheus'],
stevenvanrossem2fdfbf42016-05-13 15:08:47 +0200113 help="setup/stop a metric/flow to be monitored or query Prometheus")
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100114parser.add_argument(
115 "--vnf_name", "-vnf", dest="vnf_name",
stevenvanrossembbdb5ee2016-04-15 15:18:44 +0200116 help="vnf name:interface to be monitored")
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100117parser.add_argument(
stevenvanrossemed711fd2016-04-11 16:59:29 +0200118 "--metric", "-m", dest="metric",
stevenvanrossema24b4372016-04-14 09:55:20 +0200119 help="tx_bytes, rx_bytes, tx_packets, rx_packets")
stevenvanrossem461941c2016-05-10 11:41:29 +0200120parser.add_argument(
121 "--cookie", "-c", dest="cookie",
122 help="flow cookie to monitor")
123parser.add_argument(
124 "--query", "-q", dest="query",
125 help="prometheus query")
126parser.add_argument(
127 "--datacenter", "-d", dest="datacenter",
128 help="Data center where the vnf is deployed")
stevenvanrossem994245b2016-05-04 12:36:57 +0200129
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100130def main(argv):
stevenvanrossema24b4372016-04-14 09:55:20 +0200131 #print "This is the son-emu monitor CLI."
132 #print "Arguments: %s" % str(argv)
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100133 args = vars(parser.parse_args(argv))
134 c = ZeroRpcClient()
135 c.execute_command(args)