-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_remote.py
102 lines (81 loc) · 3.32 KB
/
run_remote.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
import argparse
import threading
import fabric
from fabric import Connection
from random import random
import paramiko
import time
class Jetson:
def __init__(self, min_port, max_port):
self.address = "147.47.200.209"
self.username, self.password = "jetson", "jetson"
self.ports = [i for i in range(int(min_port), int(max_port)+1) if 1<=i%10<=6]
self.jetson_ports = []
self.connections = []
def check(self):
for port in self.ports:
con = Connection(f'{self.username}@{self.address}:{port}', connect_kwargs ={"password":self.password})
command = 'ls'
print(f'----------------{port}----------------')
try:
con.run(command)
self.jetson_ports.append(port)
self.connections.append(con)
except:
print('ERROR')
print("Available ports", self.jetson_ports)
def send_command(self, command):
for port, con in zip(self.jetson_ports, self.connections):
print(f'----------------{port}----------------')
try:
con.run(command)
except:
print('ERROR')
def start_fed(self, host, port):
threads = []
for i, (port, con) in enumerate(zip(self.jetson_ports, self.connections)):
command = f'docker exec client python3 /ambient_fl/socket/test_single_client.py --id {i} --host 147.47.200.209 --port 20000'
print(f'----------------{port}----------------')
try:
t=threading.Thread(target=con.run,args=(command,))
threads.append(t)
t.start()
time.sleep(2)
except:
print('ERROR')
for thread in threads:
thread.join()
if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument("--host", default="147.47.200.209", type=str)
parser.add_argument("--port", default=20000, type=int)
parser.add_argument("--min", default=20101, type=int)
parser.add_argument("--max", default=20136, type=int)
args = parser.parse_args()
jetson = Jetson(min_port = args.min, max_port=args.max)
jetson.check() # 통신 전에 무조건 실행되야 함
print("\n")
print("Kill all containers")
jetson.send_command("docker kill $(docker ps -q)")
print("...completed")
print("\n")
print("Remove 'client' container")
jetson.send_command("docker rm client")
print("...completed")
print("\n")
print("Pull latest image")
jetson.send_command("docker pull crazyboy9103/jetson_fl:latest")
print("...completed")
print("\n")
print("Running the container")
jetson.send_command("docker run -d -ti --name client --gpus all crazyboy9103/jetson_fl:latest")
print("...completed")
print("\n")
#print("Git pull")
#jetson.send_command("docker exec client cd ambient_fl && git pull")
#print("...completed")
print("\n")
print("Starting federated learning")
jetson.start_fed(host=args.host, port=args.port)
jetson.send_command("docker rm client")
print("Federated learning done")