2021-10-26 14:53:56 +08:00
|
|
|
# Copyright 2021 Memgraph Ltd.
|
|
|
|
#
|
|
|
|
# Use of this software is governed by the Business Source License
|
|
|
|
# included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
|
|
|
|
# License, and you may not use this file except in compliance with the Business Source License.
|
|
|
|
#
|
|
|
|
# As of the Change Date specified in that file, in accordance with
|
|
|
|
# the Business Source License, use of this software will be governed
|
|
|
|
# by the Apache License, Version 2.0, included in the file
|
|
|
|
# licenses/APL.txt.
|
|
|
|
|
2017-09-12 21:25:43 +08:00
|
|
|
import logging
|
|
|
|
import os
|
|
|
|
import subprocess
|
|
|
|
from argparse import ArgumentParser
|
|
|
|
from collections import defaultdict
|
|
|
|
import tempfile
|
|
|
|
import shutil
|
|
|
|
import time
|
2017-10-19 18:39:41 +08:00
|
|
|
from common import get_absolute_path, set_cpus
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
try:
|
|
|
|
import jail
|
|
|
|
except:
|
|
|
|
import jail_faker as jail
|
|
|
|
|
|
|
|
|
2017-11-07 00:33:29 +08:00
|
|
|
def wait_for_server(port, delay=0.1):
|
2017-09-12 21:25:43 +08:00
|
|
|
cmd = ["nc", "-z", "-w", "1", "127.0.0.1", port]
|
|
|
|
while subprocess.call(cmd) != 0:
|
2017-11-07 00:33:29 +08:00
|
|
|
time.sleep(0.01)
|
2017-09-12 21:25:43 +08:00
|
|
|
time.sleep(delay)
|
|
|
|
|
|
|
|
|
|
|
|
class Memgraph:
|
|
|
|
"""
|
|
|
|
Knows how to start and stop memgraph.
|
|
|
|
"""
|
2019-12-08 18:35:50 +08:00
|
|
|
def __init__(self, args, num_workers):
|
2017-09-12 21:25:43 +08:00
|
|
|
self.log = logging.getLogger("MemgraphRunner")
|
|
|
|
argp = ArgumentParser("MemgraphArgumentParser")
|
|
|
|
argp.add_argument("--runner-bin",
|
|
|
|
default=get_absolute_path("memgraph", "build"))
|
|
|
|
argp.add_argument("--port", default="7687",
|
|
|
|
help="Database and client port")
|
2019-12-05 20:24:30 +08:00
|
|
|
argp.add_argument("--data-directory", default=None)
|
|
|
|
argp.add_argument("--storage-snapshot-on-exit", action="store_true")
|
|
|
|
argp.add_argument("--storage-recover-on-startup", action="store_true")
|
2017-09-12 21:25:43 +08:00
|
|
|
self.log.info("Initializing Runner with arguments %r", args)
|
|
|
|
self.args, _ = argp.parse_known_args(args)
|
|
|
|
self.num_workers = num_workers
|
|
|
|
self.database_bin = jail.get_process()
|
2018-08-10 20:35:43 +08:00
|
|
|
self.name = "memgraph"
|
2017-10-19 18:39:41 +08:00
|
|
|
set_cpus("database-cpu-ids", self.database_bin, args)
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
def start(self):
|
|
|
|
self.log.info("start")
|
2019-12-08 18:42:59 +08:00
|
|
|
database_args = ["--bolt-port", self.args.port,
|
2019-12-08 18:35:50 +08:00
|
|
|
"--query-execution-timeout-sec", "0"]
|
2017-09-12 21:25:43 +08:00
|
|
|
if self.num_workers:
|
2019-12-08 18:42:59 +08:00
|
|
|
database_args += ["--bolt-num-workers", str(self.num_workers)]
|
2019-12-05 20:24:30 +08:00
|
|
|
if self.args.data_directory:
|
|
|
|
database_args += ["--data-directory", self.args.data_directory]
|
|
|
|
if self.args.storage_recover_on_startup:
|
|
|
|
database_args += ["--storage-recover-on-startup"]
|
|
|
|
if self.args.storage_snapshot_on_exit:
|
|
|
|
database_args += ["--storage-snapshot-on-exit"]
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
# find executable path
|
|
|
|
runner_bin = self.args.runner_bin
|
|
|
|
|
|
|
|
# start memgraph
|
2019-12-08 18:35:50 +08:00
|
|
|
self.database_bin.run(runner_bin, database_args, timeout=600)
|
2017-09-12 21:25:43 +08:00
|
|
|
wait_for_server(self.args.port)
|
|
|
|
|
|
|
|
def stop(self):
|
|
|
|
self.database_bin.send_signal(jail.SIGTERM)
|
|
|
|
self.database_bin.wait()
|
|
|
|
|
|
|
|
|
|
|
|
class Neo:
|
|
|
|
"""
|
|
|
|
Knows how to start and stop neo4j.
|
|
|
|
"""
|
2017-10-19 18:39:41 +08:00
|
|
|
def __init__(self, args, config):
|
2017-09-12 21:25:43 +08:00
|
|
|
self.log = logging.getLogger("NeoRunner")
|
|
|
|
argp = ArgumentParser("NeoArgumentParser")
|
|
|
|
argp.add_argument("--runner-bin", default=get_absolute_path(
|
|
|
|
"neo4j/bin/neo4j", "libs"))
|
|
|
|
argp.add_argument("--port", default="7687",
|
|
|
|
help="Database and client port")
|
|
|
|
argp.add_argument("--http-port", default="7474",
|
|
|
|
help="Database and client port")
|
|
|
|
self.log.info("Initializing Runner with arguments %r", args)
|
|
|
|
self.args, _ = argp.parse_known_args(args)
|
|
|
|
self.config = config
|
|
|
|
self.database_bin = jail.get_process()
|
2018-08-10 20:35:43 +08:00
|
|
|
self.name = "neo4j"
|
2017-10-19 18:39:41 +08:00
|
|
|
set_cpus("database-cpu-ids", self.database_bin, args)
|
2017-09-12 21:25:43 +08:00
|
|
|
|
|
|
|
def start(self):
|
|
|
|
self.log.info("start")
|
|
|
|
|
|
|
|
# create home directory
|
|
|
|
self.neo4j_home_path = tempfile.mkdtemp(dir="/dev/shm")
|
|
|
|
|
|
|
|
try:
|
|
|
|
os.symlink(os.path.join(get_absolute_path("neo4j", "libs"), "lib"),
|
|
|
|
os.path.join(self.neo4j_home_path, "lib"))
|
|
|
|
neo4j_conf_dir = os.path.join(self.neo4j_home_path, "conf")
|
|
|
|
neo4j_conf_file = os.path.join(neo4j_conf_dir, "neo4j.conf")
|
|
|
|
os.mkdir(neo4j_conf_dir)
|
|
|
|
shutil.copyfile(self.config, neo4j_conf_file)
|
|
|
|
with open(neo4j_conf_file, "a") as f:
|
|
|
|
f.write("\ndbms.connector.bolt.listen_address=:" +
|
|
|
|
self.args.port + "\n")
|
|
|
|
f.write("\ndbms.connector.http.listen_address=:" +
|
|
|
|
self.args.http_port + "\n")
|
|
|
|
|
|
|
|
# environment
|
|
|
|
cwd = os.path.dirname(self.args.runner_bin)
|
|
|
|
env = {"NEO4J_HOME": self.neo4j_home_path}
|
|
|
|
|
|
|
|
self.database_bin.run(self.args.runner_bin, args=["console"],
|
|
|
|
env=env, timeout=600, cwd=cwd)
|
|
|
|
except:
|
|
|
|
shutil.rmtree(self.neo4j_home_path)
|
|
|
|
raise Exception("Couldn't run Neo4j!")
|
|
|
|
|
|
|
|
wait_for_server(self.args.http_port, 2.0)
|
|
|
|
|
|
|
|
def stop(self):
|
|
|
|
self.database_bin.send_signal(jail.SIGTERM)
|
|
|
|
self.database_bin.wait()
|
|
|
|
if os.path.exists(self.neo4j_home_path):
|
|
|
|
shutil.rmtree(self.neo4j_home_path)
|