blob: 79ff25be00bb389c4a55878f3677be1352240f04 [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>
4"""
5
6import argparse
7import pprint
stevenvanrossemc5a536a2016-02-16 14:52:39 +01008import zerorpc
stevenvanrossem2fdfbf42016-05-13 15:08:47 +02009import prometheus
stevenvanrossemc5a536a2016-02-16 14:52:39 +010010
11pp = pprint.PrettyPrinter(indent=4)
12
13class ZeroRpcClient(object):
14
15 def __init__(self):
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020016 # network zerorpc
stevenvanrossemc5a536a2016-02-16 14:52:39 +010017 self.c = zerorpc.Client()
18 # TODO connect to DCNetwork API
19 #self.c.connect("tcp://127.0.0.1:4242") # TODO hard coded for now. we'll change this later
20 self.c.connect("tcp://127.0.0.1:5151")
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020021
22 # compute zerorpc
23 self.compute_api = zerorpc.Client(heartbeat=None, timeout=120) # heartbeat=None, timeout=120
24 self.compute_api.connect("tcp://127.0.0.1:4242") # TODO hard coded for now. we'll change this later
25
stevenvanrossemc5a536a2016-02-16 14:52:39 +010026 self.cmds = {}
27
28 def execute_command(self, args):
29 if getattr(self, args["command"]) is not None:
30 # call the local method with the same name as the command arg
31 getattr(self, args["command"])(args)
32 else:
33 print "Command not implemented."
34
stevenvanrossema24b4372016-04-14 09:55:20 +020035 def setup_metric(self, args):
stevenvanrossemed711fd2016-04-11 16:59:29 +020036 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
37 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
stevenvanrossema24b4372016-04-14 09:55:20 +020038 r = self.c.setup_metric(
39 vnf_name,
40 vnf_interface,
41 args.get("metric"))
42 pp.pprint(r)
stevenvanrossemb098cb52016-04-15 13:28:23 +020043
stevenvanrossembbdb5ee2016-04-15 15:18:44 +020044 def stop_metric(self, args):
stevenvanrossemb098cb52016-04-15 13:28:23 +020045 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
46 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
stevenvanrossem300e1e52016-04-22 22:17:51 +020047 r = self.c.stop_metric(
stevenvanrossemed711fd2016-04-11 16:59:29 +020048 vnf_name,
49 vnf_interface,
stevenvanrossemed711fd2016-04-11 16:59:29 +020050 args.get("metric"))
stevenvanrossemb098cb52016-04-15 13:28:23 +020051 pp.pprint(r)
stevenvanrossemc5a536a2016-02-16 14:52:39 +010052
stevenvanrossem461941c2016-05-10 11:41:29 +020053 def setup_flow(self, args):
54 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
55 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
56 r = self.c.setup_flow(
57 vnf_name,
58 vnf_interface,
59 args.get("metric"),
60 args.get("cookie"))
61 pp.pprint(r)
62
stevenvanrossem81955a52016-05-12 14:34:12 +020063 def stop_flow(self, args):
64 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
65 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
66 r = self.c.stop_flow(
67 vnf_name,
68 vnf_interface,
69 args.get("metric"),
70 args.get("cookie"))
71 pp.pprint(r)
72
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020073 def prometheus_zrpc(self, args):
stevenvanrossem461941c2016-05-10 11:41:29 +020074 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
75 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
76 r = self.c.prometheus(
77 args.get("datacenter"),
78 vnf_name,
79 vnf_interface,
80 args.get("query"))
81 pp.pprint(r)
82
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020083 def prometheus(self, args):
84 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
85 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
86 dc_label = args.get("datacenter")
87 query = args.get("query")
88 vnf_status = self.compute_api.compute_status(dc_label, vnf_name)
89 uuid = vnf_status['id']
90 query = query.replace('<uuid>', uuid)
91
92 r = prometheus.query_Prometheus(query)
93 pp.pprint(r)
94
stevenvanrossem461941c2016-05-10 11:41:29 +020095
stevenvanrossemed711fd2016-04-11 16:59:29 +020096 def _parse_vnf_name(self, vnf_name_str):
97 vnf_name = vnf_name_str.split(':')[0]
98 return vnf_name
99
100 def _parse_vnf_interface(self, vnf_name_str):
101 try:
102 vnf_interface = vnf_name_str.split(':')[1]
103 except:
104 vnf_interface = None
105
106 return vnf_interface
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100107
stevenvanrossem461941c2016-05-10 11:41:29 +0200108parser = argparse.ArgumentParser(description='son-emu monitor')
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100109parser.add_argument(
110 "command",
stevenvanrossem81955a52016-05-12 14:34:12 +0200111 choices=['setup_metric', 'stop_metric', 'setup_flow', 'stop_flow','prometheus'],
stevenvanrossem2fdfbf42016-05-13 15:08:47 +0200112 help="setup/stop a metric/flow to be monitored or query Prometheus")
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100113parser.add_argument(
114 "--vnf_name", "-vnf", dest="vnf_name",
stevenvanrossembbdb5ee2016-04-15 15:18:44 +0200115 help="vnf name:interface to be monitored")
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100116parser.add_argument(
stevenvanrossemed711fd2016-04-11 16:59:29 +0200117 "--metric", "-m", dest="metric",
stevenvanrossema24b4372016-04-14 09:55:20 +0200118 help="tx_bytes, rx_bytes, tx_packets, rx_packets")
stevenvanrossem461941c2016-05-10 11:41:29 +0200119parser.add_argument(
120 "--cookie", "-c", dest="cookie",
121 help="flow cookie to monitor")
122parser.add_argument(
123 "--query", "-q", dest="query",
124 help="prometheus query")
125parser.add_argument(
126 "--datacenter", "-d", dest="datacenter",
127 help="Data center where the vnf is deployed")
stevenvanrossem994245b2016-05-04 12:36:57 +0200128
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100129def main(argv):
stevenvanrossema24b4372016-04-14 09:55:20 +0200130 #print "This is the son-emu monitor CLI."
131 #print "Arguments: %s" % str(argv)
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100132 args = vars(parser.parse_args(argv))
133 c = ZeroRpcClient()
134 c.execute_command(args)