2017-09-12 21:25:43 +08:00
|
|
|
import logging
|
|
|
|
from argparse import ArgumentParser
|
2017-11-20 17:08:44 +08:00
|
|
|
from common import get_absolute_path, APOLLO
|
2017-09-12 21:25:43 +08:00
|
|
|
from databases import Memgraph, Neo
|
|
|
|
from clients import QueryClient, LongRunningClient
|
|
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class LongRunningSuite:
|
|
|
|
KNOWN_KEYS = {"config", "setup", "run"}
|
2018-01-23 22:31:57 +08:00
|
|
|
headers = ["elapsed_time", "num_executed_queries"]
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
def __init__(self, args):
|
|
|
|
argp = ArgumentParser("LongRunningSuiteArgumentParser")
|
2017-09-19 21:31:44 +08:00
|
|
|
argp.add_argument("--duration", type=int)
|
2017-09-12 21:25:43 +08:00
|
|
|
self.args, _ = argp.parse_known_args(args)
|
|
|
|
pass
|
|
|
|
|
|
|
|
def run(self, scenario, group_name, scenario_name, runner):
|
|
|
|
runner.start()
|
|
|
|
|
2017-09-14 03:20:03 +08:00
|
|
|
log.info("Executing setup")
|
2017-11-20 17:08:44 +08:00
|
|
|
runner.setup(scenario.get("setup")())
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
config = next(scenario.get("config")())
|
|
|
|
duration = config["duration"]
|
2017-09-19 21:31:44 +08:00
|
|
|
if self.args.duration:
|
|
|
|
duration = self.args.duration
|
2017-11-20 17:08:44 +08:00
|
|
|
log.info("Executing run for {} seconds".format(
|
|
|
|
duration))
|
2018-01-27 01:50:16 +08:00
|
|
|
results = runner.run(next(scenario.get("run")()), duration, config["client"])
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
runner.stop()
|
|
|
|
|
|
|
|
measurements = []
|
2018-08-10 20:35:43 +08:00
|
|
|
summary_format = "{:>15} {:>22} {:>22}\n"
|
2017-09-19 21:31:44 +08:00
|
|
|
self.summary = summary_format.format(
|
2018-08-10 20:35:43 +08:00
|
|
|
"elapsed_time", "num_executed_queries", "num_executed_steps")
|
2017-09-12 21:25:43 +08:00
|
|
|
for result in results:
|
2017-09-19 21:31:44 +08:00
|
|
|
self.summary += summary_format.format(
|
2018-08-10 20:35:43 +08:00
|
|
|
result["elapsed_time"], result["num_executed_queries"],
|
|
|
|
result["num_executed_steps"])
|
2017-09-12 21:25:43 +08:00
|
|
|
measurements.append({
|
|
|
|
"target": "throughput",
|
2018-01-23 22:31:57 +08:00
|
|
|
"time": result["elapsed_time"],
|
|
|
|
"value": result["num_executed_queries"],
|
2018-08-10 20:35:43 +08:00
|
|
|
"steps": result["num_executed_steps"],
|
2018-01-23 22:31:57 +08:00
|
|
|
"unit": "number of executed queries",
|
2017-09-12 21:25:43 +08:00
|
|
|
"type": "throughput"})
|
2018-08-10 20:35:43 +08:00
|
|
|
self.summary += "\n\nThroughput: " + str(measurements[-1]["value"])
|
|
|
|
self.summary += "\nExecuted steps: " + str(measurements[-1]["steps"])
|
2017-09-12 21:25:43 +08:00
|
|
|
return measurements
|
|
|
|
|
|
|
|
def runners(self):
|
2018-01-23 22:31:57 +08:00
|
|
|
return {"MemgraphRunner": MemgraphRunner, "NeoRunner": NeoRunner}
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
def groups(self):
|
2018-08-10 20:35:43 +08:00
|
|
|
return ["pokec", "card_fraud", "bfs_pokec"]
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
|
|
|
|
class _LongRunningRunner:
|
2018-08-10 20:35:43 +08:00
|
|
|
def __init__(self, args, database, num_client_workers, workload):
|
2017-09-12 21:25:43 +08:00
|
|
|
self.log = logging.getLogger("_LongRunningRunner")
|
|
|
|
self.database = database
|
2017-11-20 17:08:44 +08:00
|
|
|
self.query_client = QueryClient(args, num_client_workers)
|
2018-08-10 20:35:43 +08:00
|
|
|
self.long_running_client = LongRunningClient(args, num_client_workers,
|
|
|
|
workload)
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
def start(self):
|
|
|
|
self.database.start()
|
|
|
|
|
2017-11-20 17:08:44 +08:00
|
|
|
def setup(self, queries, num_client_workers=None):
|
2017-09-12 21:25:43 +08:00
|
|
|
return self.query_client(queries, self.database, num_client_workers)
|
|
|
|
|
2018-01-27 01:50:16 +08:00
|
|
|
def run(self, config, duration, client, num_client_workers=None):
|
2017-09-12 21:25:43 +08:00
|
|
|
return self.long_running_client(
|
2018-01-27 01:50:16 +08:00
|
|
|
config, self.database, duration, client, num_client_workers)
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
def stop(self):
|
|
|
|
self.log.info("stop")
|
|
|
|
self.database.stop()
|
|
|
|
|
|
|
|
|
2017-11-20 17:08:44 +08:00
|
|
|
# TODO: This is mostly copy pasted from MemgraphParallelRunner from
|
|
|
|
# query_suite.py. Think of the way to remove duplication.
|
2017-09-12 21:25:43 +08:00
|
|
|
class MemgraphRunner(_LongRunningRunner):
|
|
|
|
"""
|
2017-11-20 17:08:44 +08:00
|
|
|
Configures memgraph database for LongRunningSuite execution.
|
2017-09-12 21:25:43 +08:00
|
|
|
"""
|
|
|
|
def __init__(self, args):
|
|
|
|
argp = ArgumentParser("MemgraphRunnerArgumentParser")
|
2017-11-20 17:08:44 +08:00
|
|
|
argp.add_argument("--num-database-workers", type=int, default=8,
|
|
|
|
help="Number of workers")
|
|
|
|
argp.add_argument("--num-client-workers", type=int, default=24,
|
|
|
|
help="Number of clients")
|
2018-08-10 20:35:43 +08:00
|
|
|
argp.add_argument("--workload", type=str, default="",
|
|
|
|
help="Type of client workload. Sets \
|
|
|
|
scenario flag for 'TestClient'")
|
2017-09-12 21:25:43 +08:00
|
|
|
self.args, remaining_args = argp.parse_known_args(args)
|
2017-11-20 17:08:44 +08:00
|
|
|
assert not APOLLO or self.args.num_database_workers, \
|
2018-01-23 22:31:57 +08:00
|
|
|
"--num-database-workers is obligatory flag on apollo"
|
2017-11-20 17:08:44 +08:00
|
|
|
assert not APOLLO or self.args.num_client_workers, \
|
2018-01-23 22:31:57 +08:00
|
|
|
"--num-client-workers is obligatory flag on apollo"
|
2019-12-08 18:35:50 +08:00
|
|
|
database = Memgraph(remaining_args, self.args.num_database_workers)
|
2017-11-20 17:08:44 +08:00
|
|
|
super(MemgraphRunner, self).__init__(
|
2018-08-10 20:35:43 +08:00
|
|
|
remaining_args, database, self.args.num_client_workers,
|
|
|
|
self.args.workload)
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
|
|
|
|
class NeoRunner(_LongRunningRunner):
|
|
|
|
"""
|
|
|
|
Configures neo4j database for QuerySuite execution.
|
|
|
|
"""
|
|
|
|
def __init__(self, args):
|
|
|
|
argp = ArgumentParser("NeoRunnerArgumentParser")
|
|
|
|
argp.add_argument("--runner-config",
|
2017-11-20 17:08:44 +08:00
|
|
|
default=get_absolute_path("config/neo4j.conf"),
|
2017-09-12 21:25:43 +08:00
|
|
|
help="Path to neo config file")
|
2017-11-20 17:08:44 +08:00
|
|
|
argp.add_argument("--num-client-workers", type=int, default=24,
|
|
|
|
help="Number of clients")
|
2018-08-10 20:35:43 +08:00
|
|
|
argp.add_argument("--workload", type=str, default="",
|
|
|
|
help="Type of client workload. Sets \
|
|
|
|
scenario flag for 'TestClient'")
|
2017-09-12 21:25:43 +08:00
|
|
|
self.args, remaining_args = argp.parse_known_args(args)
|
2017-11-20 17:08:44 +08:00
|
|
|
assert not APOLLO or self.args.num_client_workers, \
|
2018-01-23 22:31:57 +08:00
|
|
|
"--client-num-clients is obligatory flag on apollo"
|
2017-11-20 17:08:44 +08:00
|
|
|
database = Neo(remaining_args, self.args.runner_config)
|
|
|
|
super(NeoRunner, self).__init__(
|
2018-08-10 20:35:43 +08:00
|
|
|
remaining_args, database, self.args.num_client_workers,
|
|
|
|
self.args.workload)
|