1 from bigquery_analytics import BigQueryAnalytics
4 class PlanetStackAnalytics(BigQueryAnalytics):
5 def __init__(self, tableName="demoevents"):
6 BigQueryAnalytics.__init__(self, tableName)
8 def compose_query(self, slice=None, site=None, node=None, timeField="MinuteTime", avg=[], sum=[], count=[], computed=[], groupBy=["MinuteTime"], orderBy=["MinuteTime"], tableName="demoevents"):
9 tablePart = "%s.%s@-3600000--1" % ("vicci", tableName)
14 if (timeField=="MinuteTime"):
15 fields.append("INTEGER(TIMESTAMP_TO_SEC(time)/60)*60 as MinuteTime")
16 elif (timeField=="HourTime"):
17 fields.append("INTEGER(TIMESTAMP_TO_SEC(time)/60/60)*60*60 as HourTime")
18 elif (timeField=="DayTime"):
19 fields.append("INTEGER(TIMESTAMP_TO_SEC(time)/60/60/24)*60*60*24 as DayTime")
22 fields.append("AVG(%s) as avg_%s" % (fieldName, fieldName.replace("%","")))
23 fieldNames.append("avg_%s" % fieldName.replace("%",""))
26 fields.append("SUM(%s) as sum_%s" % (fieldName, fieldName.replace("%","")))
27 fieldNames.append("sum_%s" % fieldName.replace("%",""))
29 for fieldName in count:
30 fields.append("COUNT(distinct %s) as count_%s" % (fieldName, fieldName.replace("%","")))
31 fieldNames.append("count_%s" % fieldName.replace("%",""))
33 for fieldName in computed:
35 parts = fieldName.split("/")
36 computedFieldName = "computed_" + parts[0].replace("%","")+"_div_"+parts[1].replace("%","")
39 parts = computed.split("*")
40 computedFieldName = "computed_" + parts[0].replace("%","")+"_mult_"+parts[1].replace("%","")
41 fields.append("SUM(%s)%sSUM(%s) as %s" % (parts[0], operator, parts[1], computedFieldName))
42 fieldNames.append(computedFieldName)
44 fields = ", ".join(fields)
49 where.append("%%slice='%s'" % slice)
51 where.append("%%site='%s'" % site)
53 where.append("%%hostname='%s'" % node)
56 where = " WHERE " + " AND ".join(where)
61 groupBy = " GROUP BY " + ",".join(groupBy)
66 orderBy = " ORDER BY " + ",".join(orderBy)
71 subQuery = "SELECT %%hostname, %s FROM [%s]" % (fields, tablePart)
73 subQuery = subQuery + where
74 subQuery = subQuery + " GROUP BY %s,%%hostname" % timeField
77 for fieldName in fieldNames:
78 if fieldName.startswith("avg"):
79 sumFields.append("AVG(%s) as avg_%s"%(fieldName,fieldName))
81 sumFields.append("SUM(%s) as sum_%s"%(fieldName,fieldName))
83 sumFields = ",".join(sumFields)
85 query = "SELECT %s, %s FROM (%s)" % (timeField, sumFields, subQuery)
87 query = query + groupBy
89 query = query + orderBy
91 query = "SELECT %s FROM [%s]" % (fields, tablePart)
93 query = query + " " + where
95 query = query + groupBy
97 query = query + orderBy
101 def get_list_from_req(self, req, name, default=[]):
102 value = req.GET.get(name, None)
105 return value.split(",")
107 def format_result(self, format, result, query):
108 if (format == "json_dicts"):
109 result = {"query": query, "rows": result}
110 return ("application/javascript", json.dumps(result))
112 elif (format == "json_arrays"):
116 for key in sorted(row.keys()):
117 new_row.append(row[key])
118 new_result.append(new_row)
119 new_result = {"query": query, "rows": new_result}
120 return ("application/javascript", json.dumps(new_result))
122 elif (format == "html_table"):
126 for key in sorted(row.keys()):
127 new_row.append("<TD>%s</TD>" % str(row[key]))
128 new_rows.append("<TR>%s</TR>" % "".join(new_row))
130 new_result = "<TABLE>%s</TABLE>" % "\n".join(new_rows)
132 return ("text/html", new_result)
134 def process_request(self, req):
137 tqx = req.GET.get("reqId", None)
139 slice = req.GET.get("slice", None)
140 site = req.GET.get("site", None)
141 node = req.GET.get("node", None)
143 format = req.GET.get("format", "json_dicts")
145 timeField = req.GET.get("timeField", "MinuteTime")
146 avg = self.get_list_from_req(req, "avg")
147 sum = self.get_list_from_req(req, "sum")
148 count = self.get_list_from_req(req, "count")
149 computed = self.get_list_from_req(req, "computed")
150 groupBy = self.get_list_from_req(req, "groupBy", ["MinuteTime"])
151 orderBy = self.get_list_from_req(req, "orderBy", ["MinuteTime"])
153 maxRows = req.GET.get("maxRows", None)
155 q = self.compose_query(slice, site, node, timeField, avg, sum, count, computed, groupBy, orderBy)
160 result = self.run_query_raw(q)
161 result["reqId"] = 0 # XXX FIXME
162 return ("application/javascript", json.dumps(result))
164 result = self.run_query(q)
167 result = result[-int(maxRows):]
169 return self.format_result(format, result, q)
172 def DoPlanetStackAnalytics(request):
173 bq = PlanetStackAnalytics()
174 result = bq.process_request(request)
179 bq = PlanetStackAnalytics()
181 q=bq.compose_query(avg=["%cpu"], count=["%hostname"], slice="HyperCache")
183 bq.dump_table(bq.run_query(q))
185 q=bq.compose_query(computed=["%bytes_sent/%elapsed"])
188 bq.dump_table(bq.run_query(q))
189 #print bq.run_query_raw(q)
191 q=bq.compose_query(timeField="HourTime", avg=["%cpu"], count=["%hostname"], computed=["%bytes_sent/%elapsed"], groupBy=["HourTime"], orderBy=["HourTime"])
194 bq.dump_table(bq.run_query(q))
196 if __name__ == "__main__":