forked from PlaZMaD/run_ship_at
-
Notifications
You must be signed in to change notification settings - Fork 1
/
run_at_azure.py
68 lines (55 loc) · 3.03 KB
/
run_at_azure.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
import azure.common
import azure.mgmt.containerinstance
import azure.mgmt.resource
print(azure.common.__version__)
print(azure.mgmt.containerinstance.__version__)
print(azure.mgmt.resource.__version__)
from cloudhunky.aci_worker import ACIWorker
from cloudhunky.util import get_afs_creds
import logging
from multiprocessing import Process
fileN = 2
jobsNum = 200
# command = ["/bin/bash", "-c", "./scripts/run_fs.sh"]
def run_job(envs):
resource_group_name = "SHIP"
aci_worker = ACIWorker(resource_group_name)
container_image_name="mrphys/mfsimage:coMagnetAzure"
volume_mount_path = "/sample"
afs_creds = get_afs_creds()
afs_name = afs_creds["AFS_NAME"]
afs_key = afs_creds["AFS_KEY"]
afs_share = afs_creds["AFS_SHARE"]
container_group_name, logs = aci_worker.run_task_based_container(container_image_name=container_image_name,
#command=command,
cpu=1.0,
memory_in_gb=8,
gpu_count=0,
volume_mount_path=volume_mount_path,
envs=envs,
timeout=28800,
afs_name=afs_name,
afs_key=afs_key,
afs_share=afs_share,
afs_mount_subpath='')
fileLen = {0: 13450391, 16000: 6242698, 66000: 6112412, 27000: 6238416, 63000: 6242811, 21000: 6236055, 34000: 6241933, 57000: 6240829, 10000: 6237695, 23000: 6234706, 26000: 6241631, 15000: 6245846, 60000: 6239611, 58000: 6235854, 29000: 6237372, 31000: 6238463, 39000: 6244654, 4000: 6237671, 22000: 2110646, 44000: 2793980, 59000: 6235770, 9000: 6239653, 47000: 6236843, 36000: 6239944, 14000: 6239735, 5000: 6238535, 45000: 6238019, 51000: 6242407, 41000: 6240065, 19000: 6234737, 49000: 6238063, 55000: 6240257, 33000: 6240302, 8000: 6239151, 20000: 6238057, 25000: 6236993, 61000: 6236622, 13000: 6244139, 38000: 6239812, 52000: 6243558, 30000: 6238488, 2000: 6238126, 3000: 6239983, 43000: 6239453, 28000: 6234302, 7000: 6246430, 53000: 6237809, 35000: 6238593, 56000: 6239181, 12000: 6239670, 18000: 6242505, 48000: 6238654, 54000: 6240632, 1000: 6240925, 62000: 3702269, 42000: 6242558, 64000: 6239932, 32000: 3881168, 6000: 6242602, 17000: 6243827, 40000: 6237918, 24000: 6238708, 50000: 5520395, 11000: 6238705, 65000: 6239301, 37000: 6238285, 46000: 6240834}
procs = []
nEvents_in = fileLen[fileN*1000]
#nEvents_in = 100
n = nEvents_in
k = jobsNum
startPoints = [i * (n // k) + min(i, n % k) for i in range(k)]
chunkLength = [(n // k) + (1 if i < (n % k) else 0) for i in range(k)]
chunkLength[-1] = chunkLength[-1] - 1
for i in range(100, 200):
envs = {"fileName": "pythia8_Geant4_10.0_withCharmandBeauty0_mu.root",
"mfirstEvent": startPoints[i],
"nEvents": chunkLength[i],
"muShieldDesign":9,
"jName": "coMagnet",
"jNumber": i+1}
proc = Process(target=run_job, args=(envs,))
procs.append(proc)
proc.start()
for proc in procs:
proc .join()