forked from nelsonmarcos/newrelic-tools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathquery_nr.py
78 lines (61 loc) · 2.93 KB
/
query_nr.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
'''
Module created to query the New Relic API and extract the results to insert them into a database.
'''
import datetime
import json
import os
import requests
def run_nrquery(select_statement):
""""
Run the query against the New Relic GraphQL API and return the response as a string.
"""
url = "https://api.newrelic.com/graphql"
headers = {
"Content-Type": "application/json",
"API-Key": os.environ["NEWRELIC_API_KEY"],
}
full_query = {
"query": f"""{{actor {{
account(id: {os.environ["NEWRELIC_ACCOUNT_ID"]}) {{
nrql(query: "{select_statement}") {{
results
}}
}}
}}
}}"""
}
response = requests.post(url, headers=headers, json=full_query)
return response.text
def extract_results(json_content):
"""
Extract the results from the response and return them as a list of dictionaries.
"""
output = json.loads(json_content)['data']['actor']['account']['nrql']['results']
return output
def generate_db_insert(list_of_dicts, current_time):
""""
Generate a list of SQL INSERT statements from the list of dictionaries.
"""
query_list = []
for item in list_of_dicts:
insert_query=f"INSERT INTO app_usage (date, appName, cost) VALUES ('{current_time}', '{item['appName']}', {item['Cost']});"
query_list.append(insert_query)
return query_list
select_statements=[
#Transaction and TransactionError
"SELECT bytecountestimate() / 10e8 * 24 * 30 * 12 * 0.30 * 5.15 as 'Cost' FROM `Transaction`, `TransactionError` FACET appName LIMIT 400 SINCE 1 hour ago",
#Metric
"SELECT bytecountestimate() / 10e8 * 24 * 30 * 12 * 0.30 * 5.15 as 'Cost' FROM `Metric` WHERE newrelic.source = 'agent' AND instrumentation.provider != 'kentik' AND instrumentation.provider != 'pixie' FACET appName LIMIT 400 SINCE 1 hour ago",
#Tracing
"SELECT bytecountestimate() / 10e8 * 24 * 30 * 12 * 0.30 * 5.15 as 'Cost' FROM `Span`, `ErrorTrace`, `SqlTrace` WHERE instrumentation.provider != 'pixie' FACET appName LIMIT 400 SINCE 1 hour ago",
#Log
"SELECT bytecountestimate() / 10e8 * 24 * 30 * 12 * 0.30 * 5.15 as 'Cost' FROM `Log`, `LogExtendedRecord` WHERE instrumentation.proviver != 'kentik' facet entity.name or namespace_name as 'appName' LIMIT 400 since 1 hour ago",
]
current_time = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
for select_statement in select_statements:
#Run the query and extract the results
list_of_results=extract_results(run_nrquery(select_statement))
#Generate the list of SQL INSERT statements
list_of_inserts=generate_db_insert(list_of_results, current_time)
for insert in list_of_inserts:
print (insert)