-
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathlaunch_datasites.py
75 lines (57 loc) · 1.9 KB
/
launch_datasites.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
#!/usr/bin/env python
# coding: utf-8
from threading import Thread, Event
from time import sleep
from datasites import spawn_server, check_and_approve_incoming_requests
from datasites import DATASITE_URLS
class DataSiteThread(Thread):
"""
Thread class with a stop() method.
The thread itself has to check regularly for the stopped() condition.
See here:
https://stackoverflow.com/questions/47912701/python-how-can-i-implement-a-stoppable-thread
"""
def __init__(self, *args, **kwargs):
super(DataSiteThread, self).__init__(*args, **kwargs)
self._stop_event = Event()
def stop(self):
self._stop_event.set()
def stopped(self):
return self._stop_event.is_set()
def show_connections_info():
print(f"{'='*65}")
print(
f"\n\t{len(DATASITE_URLS)} DataSite{'s' if len(DATASITE_URLS) > 1 else ''} Up and Running.",
end="\n\n",
)
for dsid, (name, url) in enumerate(DATASITE_URLS.items()):
print(f"{dsid+1}. {name}: {url}")
print(f"{'='*65}")
def launch_datasites(show_conn_info: bool = True) -> None:
data_sites = list()
client_threads = list()
for sid in range(4):
data_site, client = spawn_server(sid=sid)
data_sites.append(data_site)
client_threads.append(
DataSiteThread(
target=check_and_approve_incoming_requests, args=(client,), daemon=True
)
)
for t in client_threads:
t.start()
if show_conn_info:
show_connections_info()
try:
while True:
sleep(2)
except KeyboardInterrupt:
for data_site in data_sites:
data_site.land()
for t in client_threads:
t.stop()
def launch_from_notebook() -> None:
t = Thread(target=launch_datasites, kwargs={"show_conn_info": True}, daemon=True)
t.start()
if __name__ == "__main__":
launch_datasites()