-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathrun.py
101 lines (90 loc) · 3.3 KB
/
run.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
# coding:utf-8
# 将程序上传到服务器上执行
import os
import sys
from functools import wraps
import time
# 上传代码至服务器并运行
def run(gpus, user, server):
# 上传本目录所有文件再执行指定文件
if gpus == "all":
# 清除服务器代码目录里所有源文件以及输出目录中的文件
s = "ssh " + user + "@" + server + " \"sudo rm -rf ~/code/*.py\""
# print("测试1", s)
os.system(s)
s = "ssh " + user + "@" + server + " \"sudo rm -rf ~/code/output/*\""
# print("测试2", s)
os.system(s)
# 将本地目录所有文件上传至容器
s = "scp -r ./*.py " + user + "@" + server + ":~/code"
# print("测试3", s)
os.system(s)
# 运行指定代码
s = "ssh root@" + server + " -p 2222 \"python /home/code/" + sys.argv[2] + "\""
# print("测试4", s)
print("正在运行代码……\n")
os.system(s)
# 将代码目录里所有输出文件传回
s = "scp -r " + user +"@" + server + ":~/code/output/* ./output/"
# print("测试5", s)
os.system(s)
# 将所有结果文件传回
elif gpus == "copy":
s = "scp -r " + user + "@" + server + ":~/code/output/* ./output/"
os.system(s)
# 上传指定文件并执行
else:
## 清除服务器代码目录里所有源文件以及输出目录中的文件
s = "ssh " + user + "@" + server + " \"sudo rm -rf ~/code/*.py\""
os.system(s)
s = "ssh " + user + "@" + server + " \"sudo rm -rf ~/code/output/*\""
os.system(s)
# 将本地目录指定文件上传至容器
s = "scp " + sys.argv[1] + " " + user + "@" + server + ":~/code"
os.system(s)
# 运行指定代码
s = "ssh root@" + server + " -p 2222 \"python /home/code/" + sys.argv[1] + "\""
os.system(s)
# 将代码目录里所有文件传回
s = "scp -r " + user +"@" + server + ":~/code/output/* ./output/"
os.system(s)
# 主函数
def main():
gpus = sys.argv[1]
# 读取服务器IP地址,自己编辑serverIP.txt去
with open("serverIP.txt", "rt") as f:
server_list = f.readlines()
for s in server_list:
s = s.replace('\n', '').replace('\r', '')
# print(s)
if s[0] != "#":
res = s.split("@")
username = res[0]
server = res[1]
# print("测试", username, server)
# input("按任意键继续")
run(gpus, username, server)
return
if __name__ == "__main__":
main()
# 工具函数,在上传到服务器上运行时改变当前目录
def change_dir(func):
@wraps(func)
def change(*args, **kwargs):
oldpath = os.getcwd()
newpath = "/home/code/"
os.chdir(newpath)
r = func(*args, **kwargs)
os.chdir(oldpath)
return r
return change
# 工具函数,计算函数运行时间
def timethis(func):
@wraps(func)
def wrapper(*args, **kwargs):
start = time.perf_counter()
r = func(*args, **kwargs)
end = time.perf_counter()
print('{}.{}的运行时间为 : {}秒'.format(func.__module__, func.__name__, end - start))
return r
return wrapper