-
Notifications
You must be signed in to change notification settings - Fork 26
/
Copy pathrun_example_service.py
113 lines (94 loc) · 3.68 KB
/
run_example_service.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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
import sys
import os
import signal
import time
import subprocess
import logging
import pathlib
import glob
import json
import argparse
from service import registry
logging.basicConfig(level=10, format="%(asctime)s - [%(levelname)8s] - %(name)s - %(message)s")
log = logging.getLogger("run_example_service")
def main():
parser = argparse.ArgumentParser(description="Run services")
parser.add_argument("--no-daemon", action="store_false", dest="run_daemon", help="do not start the daemon")
parser.add_argument("--daemon-config",
dest="daemon_config",
help="Path of daemon configuration file, without config it won't be started",
required=False)
parser.add_argument("--ssl", action="store_true", dest="run_ssl", help="start the daemon with SSL")
args = parser.parse_args()
root_path = pathlib.Path(__file__).absolute().parent
# All services modules go here
service_modules = ["service.example_service"]
# Call for all the services listed in service_modules
all_p = start_all_services(root_path, service_modules, args.run_daemon, args.daemon_config, args.run_ssl)
# Continuous checking all subprocess
try:
while True:
for p in all_p:
p.poll()
if p.returncode and p.returncode != 0:
kill_and_exit(all_p)
time.sleep(1)
except Exception as e:
log.error(e)
raise
def start_all_services(cwd, service_modules, run_daemon, daemon_config, run_ssl):
"""
Loop through all service_modules and start them.
For each one, an instance of Daemon "snetd" is created.
snetd will start with configs from "snetd.config.json"
"""
all_p = []
for i, service_module in enumerate(service_modules):
service_name = service_module.split(".")[-1]
log.info("Launching {} on port {}".format(service_module, str(registry[service_name])))
all_p += start_service(cwd, service_module, run_daemon, daemon_config, run_ssl)
return all_p
def start_service(cwd, service_module, run_daemon, daemon_config, run_ssl):
"""
Starts SNET Daemon ("snetd") and the python module of the service
at the passed gRPC port.
"""
def add_ssl_configs(conf):
"""Add SSL keys to snetd.config.json"""
with open(conf, "r") as f:
snetd_configs = json.load(f)
snetd_configs["ssl_cert"] = "/opt/singnet/.certs/fullchain.pem"
snetd_configs["ssl_key"] = "/opt/singnet/.certs/privkey.pem"
with open(conf, "w") as f:
json.dump(snetd_configs, f, sort_keys=True, indent=4)
all_p = []
if run_daemon:
if daemon_config:
all_p.append(start_snetd(str(cwd), daemon_config))
else:
for idx, config_file in enumerate(glob.glob("./snetd_configs/*.json")):
if run_ssl:
add_ssl_configs(config_file)
all_p.append(start_snetd(str(cwd), config_file))
service_name = service_module.split(".")[-1]
grpc_port = registry[service_name]["grpc"]
p = subprocess.Popen([sys.executable, "-m", service_module, "--grpc-port", str(grpc_port)], cwd=str(cwd))
all_p.append(p)
return all_p
def start_snetd(cwd, config_file=None):
"""
Starts the Daemon "snetd":
"""
cmd = ["snetd", "serve"]
if config_file:
cmd = ["snetd", "serve", "--config", config_file]
return subprocess.Popen(cmd, cwd=str(cwd))
def kill_and_exit(all_p):
for p in all_p:
try:
os.kill(p.pid, signal.SIGTERM)
except Exception as e:
log.error(e)
exit(1)
if __name__ == "__main__":
main()