Skip to content

Commit

Permalink
Adding some logging to help trace
Browse files Browse the repository at this point in the history
Adding trivial logger to the mix. Also removing the need for user/pass
to be sent via config file, as we will pass that through the ES URL

Signed-off-by: Joe Talerico <rook@redhat.com>
  • Loading branch information
Joe Talerico committed Jan 15, 2024
1 parent c0f55ab commit 3f8fc05
Show file tree
Hide file tree
Showing 3 changed files with 64 additions and 20 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/pylint.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
name: Pylint

on: [push]
on: [push,pull_request]

jobs:
build:
Expand Down
2 changes: 1 addition & 1 deletion fmatch/__init__.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
"""This file is the init file of the matcher package
"""This file is the init file of the matcher package
which is used as to match and query data from elastic server"""
from fmatch.matcher import Matcher
80 changes: 62 additions & 18 deletions fmatch/matcher.py
Original file line number Diff line number Diff line change
@@ -1,28 +1,37 @@
""" metadata matcher
"""
import os
import sys
import logging
# pylint: disable=import-error
from elasticsearch7 import Elasticsearch
# pylint: disable=import-error
from elasticsearch.exceptions import NotFoundError
# pylint: disable=import-error
import pandas as pd
import yaml



ES_URL = os.getenv("ES_SERVER")


class Matcher:
""" Matcher
"""
def __init__(self, configpath="config.yaml", index="perf_scale_ci"):

def __init__(self, index="perf_scale_ci", level=logging.INFO):
self.index = index
self.es_url = ES_URL
with open(configpath, 'r',encoding='UTF-8') as file:
data = yaml.safe_load(file)
self.es = Elasticsearch([self.es_url], http_auth=[
data['username'], data['password']], timeout=30)
self.searchSize = 10000
self.logger = logging.getLogger("Matcher")
self.logger.setLevel(level)
handler = logging.StreamHandler(sys.stdout)
handler.setLevel(level)
formatter = logging.Formatter(
'%(asctime)s - %(name)s - %(levelname)s - %(message)s')
handler.setFormatter(formatter)
self.logger.addHandler(handler)
# We can set the ES logging higher if we want additional debugging
logging.getLogger("elasticsearch").setLevel(logging.WARN)
self.es = Elasticsearch([self.es_url], timeout=30)
self.data = None

def get_metadata_by_uuid(self, uuid, index=None):
Expand All @@ -39,6 +48,7 @@ def get_metadata_by_uuid(self, uuid, index=None):
}
result = {}
try:
self.logger.info("Executing query against index %s",index)
result = self.es.search(index=index, body=query)
hits = result.get('hits', {}).get('hits', [])
if hits:
Expand All @@ -47,6 +57,18 @@ def get_metadata_by_uuid(self, uuid, index=None):
print(f"UUID {uuid} not found in index {index}")
return result

def query_index(self, index, query):
""" generic query function
Args:
index (str): _description_
uuids (list): _description_
query (str) : Query to make against ES
"""
self.logger.info("Executing query against index=%s",index)
self.logger.debug("Executing query \r\n%s",query)
return self.es.search(index=index, body=query)

def get_uuid_by_metadata(self, meta, index=None):
""" get_uuid_by_metadata
"""
Expand All @@ -70,13 +92,35 @@ def get_uuid_by_metadata(self, meta, index=None):
]
}
},
"size": 10000
"size": self.searchSize
}
result = self.es.search(index=index, body=query)
result = self.query_index(index, query)
hits = result.get('hits', {}).get('hits', [])
uuids = [hit['_source']['uuid'] for hit in hits]
return uuids

def match_k8s_netperf(self, uuids):
"""_summary_
Args:
uuids (_type_): _description_
"""
index = "k8s-netperf"
ids = "\" OR uuid: \"".join(uuids)
query = {
"query": {
"query_string": {
"query": (
f'( uuid: \"{ids}\" )'
)
}
},
"size": self.searchSize
}
result = self.query_index(index, query)
runs = [item['_source'] for item in result["hits"]["hits"]]
return runs

def match_kube_burner(self, uuids):
""" match kube burner runs
Args:
Expand All @@ -95,9 +139,9 @@ def match_kube_burner(self, uuids):
)
}
},
"size": 10000
"size": self.searchSize
}
result = self.es.search(index=index, body=query)
result = self.query_index(index, query)
runs = [item['_source'] for item in result["hits"]["hits"]]
return runs

Expand Down Expand Up @@ -143,9 +187,9 @@ def burner_results(self, uuid, uuids, index):
)
}
},
"size": 10000
"size": self.searchSize
}
result = self.es.search(index=index, body=query)
result = self.query_index(index, query)
runs = [item['_source'] for item in result["hits"]["hits"]]
return runs

Expand All @@ -164,7 +208,7 @@ def burner_cpu_results(self, uuids, namespace, index):
"time": {
"terms": {
"field": "uuid.keyword",
"size": 10000
"size": self.searchSize
},
"aggs": {
"time": {
Expand All @@ -176,7 +220,7 @@ def burner_cpu_results(self, uuids, namespace, index):
"uuid": {
"terms": {
"field": "uuid.keyword",
"size": 10000
"size": self.searchSize
},
"aggs": {
"cpu": {
Expand All @@ -200,9 +244,9 @@ def burner_cpu_results(self, uuids, namespace, index):
}]
}
},
"size": 10000
"size": self.searchSize
}
runs = self.es.search(index=index, body=query)
runs = self.query_index(index, query)
data = self.parse_burner_cpu_results(runs)
return data

Expand Down

0 comments on commit 3f8fc05

Please sign in to comment.