-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexample-azure-performance.py
89 lines (72 loc) · 3.03 KB
/
example-azure-performance.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
""" Example application demonstrating job submission via bigjob
Azure implementation of BigJob is used
"""
import os
from bigjob_azure import *
import time
import pdb
NUMBER_JOBS=1
REPEATS=100
""" Test Job Submission via Azure BigJob """
if __name__ == "__main__":
##########################################################################################
# Start BigJob
# Parameter for BigJob
nodes = 1 # number nodes for agent
# current_directory=os.getcwd() +"/agent" # working directory for agent
# start pilot job (bigjob_agent)
print "Start Pilot Job/BigJob in the cloud. "
start = time.time()
bj = bigjob_azure()
bj.start_pilot_job(number_nodes=nodes)
print "Pilot Job/BigJob URL: " + bj.pilot_url + " State: " + str(bj.get_state())\
+ " Launch Time: " + str(time.time()-start) + " sec"
if(bj.get_state()=="Failed"):
print "Start of BigJob failed."
sys.exit(-1)
while (bj.get_state()!="Running"):
time.sleep(20)
print "BigJob Startup Time: " + str(time.time() - start) + " sec"
for i in range(0, REPEATS):
start= time.time()
##########################################################################################
# Submit SubJob through BigJob
jd = description() #TODO: move to SAGA JD
jd.executable = "approot\\resources\\namd\\namd2.exe"
jd.number_of_processes = "1"
jd.spmd_variation = "single"
jd.arguments = ["+p1", "NPT.conf"]
#jd.working_directory = "approot\\resources\\namd\\"
jd.working_directory = "$TEMP"
jd.output = "stdout"
jd.error = "stderr"
# file staging
#transfer = {}
#transfer ["source"] = os.getcwd() + "/remd/NPT.conf" # source for staging in (see JSDL spec)
#transfer ["target"] = jd.working_directory + "NPT.conf" # target for staging out (see JSDL spec)
#jd.filetransfer = [transfer]
jobs = []
for i in range (0, NUMBER_JOBS):
print "Start job no.: " + str(i)
sj = subjob(bigjob=bj)
sj.submit_job(jd)
jobs.append(sj)
# busy wait for completion
while 1:
try:
number_done = 0
for i in jobs:
state = str(i.get_state())
print "job: " + str(i) + " state: " + str(state) + " Time passed: " + str(time.time()-start) + " sec"
if(state=="Failed" or state=="Done"):
number_done = number_done + 1
if(state=="Running"):
time.sleep(20)
if (number_done == len(jobs)):
break
#time.sleep(20)
except KeyboardInterrupt:
break
##########################################################################################
# Cleanup - stop BigJob
#bj.cancel()