22 def get_configpath(conffile):
23 confdir = str(os.environ.get(
'RFARM_CONFDIR'))
25 print(
'RFARM_CONFDIR is not defined. Exit.')
27 cmd = confdir +
'/' + conffile +
'.conf'
32 def get_rfgetconf(conffile, item1, item2='NULL', item3='NULL'):
34 confdir = str(os.environ.get(
'RFARM_CONFDIR'))
36 print(
'RFARM_CONFDIR is not defined. Exit.')
38 cmd =
'rfgetconf ' + get_configpath(conffile) +
' ' + item1 +
' ' + item2 \
40 p = subprocess.Popen(cmd, shell=
True, stdout=subprocess.PIPE,
41 stderr=subprocess.PIPE)
43 output = p.stdout.read()
54 def run_nsmd(nsmdir, port, nsmhost):
56 if not os.path.exists(nsmdir +
'/' + nsmhost):
57 os.mkdir(nsmdir +
'/' + nsmhost)
58 nsmd = str(os.environ.get(
'BELLE2_EXTERNALS_BIN')) +
'/nsmd2 -f -p ' \
59 + port +
' -s ' + port +
' -h '
60 cmd =
'ssh ' + nsmhost +
' "cd ' + nsmdir +
'/' + nsmhost \
61 +
'; export NSMLOGDIR=' + nsmdir +
'/' + nsmhost +
';' + nsmd \
64 subprocess.Popen(cmd, shell=
True)
72 def kill_nsmd(port, nsmhost):
73 cmd =
'ssh ' + nsmhost +
' "ps -fC nsmd2 | grep ' + port \
74 +
"| awk '{print \\$2}' \" > temp.pid"
77 p = subprocess.Popen(cmd, shell=
True)
79 for line
in open(
'temp.pid',
'r'):
82 cmd =
'ssh ' + nsmhost +
' "kill ' + str(pid) +
'"'
84 p = subprocess.Popen(cmd, shell=
True)
90 def start_nsmd(conffile):
92 nsmdir = get_rfgetconf(conffile,
'system',
'nsmdir_base')
93 port = get_rfgetconf(conffile,
'system',
'nsmport')
96 ctlhost = get_rfgetconf(conffile,
'master',
'ctlhost')
97 run_nsmd(nsmdir, port, ctlhost)
98 print(
'nsmd on %s started' % ctlhost)
101 evshost = get_rfgetconf(conffile,
'distributor',
'ctlhost')
102 if ctlhost.find(evshost) == -1:
103 run_nsmd(nsmdir, port, evshost)
104 print(
'nsmd on %s started' % evshost)
107 opshost = get_rfgetconf(conffile,
'collector',
'ctlhost')
108 run_nsmd(nsmdir, port, opshost)
109 print(
'nsmd on %s started' % opshost)
112 nnodes = int(get_rfgetconf(conffile,
'processor',
'nnodes'))
113 procid = int(get_rfgetconf(conffile,
'processor',
'idbase'))
114 badlist = get_rfgetconf(conffile,
'processor',
'badlist')
115 evphostbase = get_rfgetconf(conffile,
'processor',
'ctlhostbase')
116 for i
in range(procid, procid + nnodes):
119 if badlist.find(nodeid) == -1:
120 evphost = evphostbase + nodeid
121 run_nsmd(nsmdir, port, evphost)
122 print(
'nsmd on %s started' % evphost)
125 def stop_nsmd(conffile):
126 port = get_rfgetconf(conffile,
'system',
'nsmport')
129 ctlhost = get_rfgetconf(conffile,
'master',
'ctlhost')
130 kill_nsmd(port, ctlhost)
131 print(
'nsmd on %s stopped' % ctlhost)
134 evshost = get_rfgetconf(conffile,
'distributor',
'ctlhost')
135 if ctlhost.find(evshost) == -1:
136 kill_nsmd(port, evshost)
137 print(
'nsmd on %s stopped' % evshost)
140 opshost = get_rfgetconf(conffile,
'collector',
'ctlhost')
141 kill_nsmd(port, opshost)
142 print(
'nsmd on %s stopped' % opshost)
145 nnodes = int(get_rfgetconf(conffile,
'processor',
'nnodes'))
146 procid = int(get_rfgetconf(conffile,
'processor',
'idbase'))
147 badlist = get_rfgetconf(conffile,
'processor',
'badlist')
148 evphostbase = get_rfgetconf(conffile,
'processor',
'ctlhostbase')
149 for i
in range(procid, procid + nnodes):
152 if badlist.find(nodeid) == -1:
153 evphost = evphostbase + nodeid
154 kill_nsmd(port, evphost)
155 print(
'nsmd on %s stopped' % evphost)
161 def run_eventserver(conffile):
162 evshost = get_rfgetconf(conffile,
'distributor',
'ctlhost')
163 basedir = get_rfgetconf(conffile,
'system',
'execdir_base')
164 port = get_rfgetconf(conffile,
'system',
'nsmport')
165 if not os.path.exists(basedir +
'/distributor'):
166 os.mkdir(basedir +
'/distributor')
167 cmd =
'ssh ' + evshost +
' "cd ' + basedir +
'; export NSM2_PORT=' + port \
168 +
'; rf_eventserver ' + get_configpath(conffile) \
169 +
' &> distributor/nsmlog.log" '
171 subprocess.Popen(cmd, shell=
True)
177 def stop_eventserver(conffile):
178 evshost = get_rfgetconf(conffile,
'distributor',
'ctlhost')
179 basedir = get_rfgetconf(conffile,
'system',
'execdir_base')
180 unit = get_rfgetconf(conffile,
'system',
'unitname')
181 ringbuf = get_rfgetconf(conffile,
'distributor',
'ringbuffer')
182 rbufname = unit +
':' + ringbuf
183 shmname = unit +
':distributor'
184 p = subprocess.Popen(
'rfcommand ' + conffile +
185 ' distributor RF_UNCONFIGURE', shell=
True)
187 pidfile = basedir +
'/distributor/pid.data'
188 for pid
in open(pidfile,
'r'):
189 cmd =
'ssh ' + evshost +
' "kill ' + pid +
'; removerb ' + rbufname \
190 +
"; removeshm " + shmname +
'"'
192 p = subprocess.Popen(cmd, shell=
True)
198 def run_outputserver(conffile):
199 opshost = get_rfgetconf(conffile,
'collector',
'ctlhost')
200 basedir = get_rfgetconf(conffile,
'system',
'execdir_base')
201 port = get_rfgetconf(conffile,
'system',
'nsmport')
202 if not os.path.exists(basedir +
'/collector'):
203 os.mkdir(basedir +
'/collector')
204 cmd =
'ssh ' + opshost +
' "cd ' + basedir +
'; export NSM2_PORT=' + port \
205 +
'; rf_outputserver ' + get_configpath(conffile) \
206 +
' &> collector/nsmlog.log" '
208 subprocess.Popen(cmd, shell=
True)
214 def stop_outputserver(conffile):
215 opshost = get_rfgetconf(conffile,
'collector',
'ctlhost')
216 basedir = get_rfgetconf(conffile,
'system',
'execdir_base')
217 unit = get_rfgetconf(conffile,
'system',
'unitname')
218 rbufin = get_rfgetconf(conffile,
'collector',
'ringbufin')
219 rbufout = get_rfgetconf(conffile,
'collector',
'ringbufout')
220 rbufinname = unit +
':' + rbufin
221 rbufoutname = unit +
':' + rbufout
222 shmname = unit +
':collector'
223 p = subprocess.Popen(
'rfcommand ' + conffile +
' collector RF_UNCONFIGURE', shell=
True)
225 pidfile = basedir +
'/collector/pid.data'
226 for pid
in open(pidfile,
'r'):
227 cmd =
'ssh ' + opshost +
' "kill ' + pid +
'; removerb ' + rbufinname \
228 +
'; removerb ' + rbufoutname +
'; removeshm ' + shmname \
229 +
'; clear_basf2_ipc"'
231 p = subprocess.Popen(cmd, shell=
True)
237 def run_eventprocessor(conffile):
238 hostbase = get_rfgetconf(conffile,
'processor',
'ctlhostbase')
239 nodebase = get_rfgetconf(conffile,
'processor',
'nodebase')
240 basedir = get_rfgetconf(conffile,
'system',
'execdir_base')
241 port = get_rfgetconf(conffile,
'system',
'nsmport')
242 nnodes = int(get_rfgetconf(conffile,
'processor',
'nnodes'))
243 procid = int(get_rfgetconf(conffile,
'processor',
'idbase'))
244 badlist = get_rfgetconf(conffile,
'processor',
'badlist')
245 id = int(get_rfgetconf(conffile,
'processor',
'idbase'))
247 for i
in range(procid, procid + nnodes):
248 nodenum =
'%2.2d' % i
250 if badlist.find(nodeid) == -1:
251 evphost = hostbase + nodeid
252 nodename = nodebase + nodenum
253 if not os.path.exists(basedir +
'/evp_' + nodename):
254 os.mkdir(basedir +
'/evp_' + nodename)
255 cmd =
'ssh ' + evphost +
' "cd ' + basedir +
'; export NSM2_PORT=' \
256 + port +
'; rf_eventprocessor ' + get_configpath(conffile) \
257 +
' &> evp_' + nodename +
'/nsmlog.log" '
259 subprocess.Popen(cmd, shell=
True)
265 def stop_eventprocessor(conffile):
266 hostbase = get_rfgetconf(conffile,
'processor',
'ctlhostbase')
267 nodebase = get_rfgetconf(conffile,
'processor',
'nodebase')
268 basedir = get_rfgetconf(conffile,
'system',
'execdir_base')
269 port = get_rfgetconf(conffile,
'system',
'nsmport')
270 nnodes = int(get_rfgetconf(conffile,
'processor',
'nnodes'))
271 procid = int(get_rfgetconf(conffile,
'processor',
'idbase'))
272 badlist = get_rfgetconf(conffile,
'processor',
'badlist')
273 id = int(get_rfgetconf(conffile,
'processor',
'idbase'))
275 unit = get_rfgetconf(conffile,
'system',
'unitname')
276 rbufin = get_rfgetconf(conffile,
'collector',
'ringbufin')
277 rbufout = get_rfgetconf(conffile,
'collector',
'ringbufout')
278 rbufinname = unit +
':' + rbufin
279 rbufoutname = unit +
':' + rbufout
281 for i
in range(procid, procid + nnodes):
284 if badlist.find(nodeid) == -1:
285 evphost = hostbase + nodeid
286 nodename =
'evp_' + nodebase + nodeid
287 shmname = unit +
':' + nodename
289 p = subprocess.Popen(
'rfcommand ' + conffile +
' ' + nodename +
290 ' RF_UNCONFIGURE', shell=
True)
292 pidfile = basedir +
'/' + nodename +
'/pid.data'
293 for pid
in open(pidfile,
'r'):
294 cmd =
'ssh ' + evphost +
' "kill ' + pid +
'; removerb ' \
295 + rbufinname +
'; removerb ' + rbufoutname \
296 +
'; removeshm ' + shmname +
'; clear_basf2_ipc"'
300 p = subprocess.Popen(cmd, shell=
True)
306 def run_dqmserver(conffile):
307 dqmhost = get_rfgetconf(conffile,
'dqmserver',
'ctlhost')
308 basedir = get_rfgetconf(conffile,
'system',
'execdir_base')
309 port = get_rfgetconf(conffile,
'system',
'nsmport')
310 if not os.path.exists(basedir +
'/dqmserver'):
311 os.mkdir(basedir +
'/dqmserver')
312 cmd =
'ssh ' + dqmhost +
' "cd ' + basedir +
'; export NSM2_PORT=' + port \
313 +
'; rf_dqmserver ' + get_configpath(conffile) \
314 +
' &> dqmserver/nsmlog.log" '
316 subprocess.Popen(cmd, shell=
True)
322 def stop_dqmserver(conffile):
323 dqmhost = get_rfgetconf(conffile,
'dqmserver',
'ctlhost')
324 basedir = get_rfgetconf(conffile,
'system',
'execdir_base')
325 p = subprocess.Popen(
'rfcommand ' + conffile +
' dqmserver RF_UNCONFIGURE', shell=
True)
327 pidfile = basedir +
'/dqmserver/pid.data'
328 for pid
in open(pidfile,
'r'):
329 cmd =
'ssh ' + dqmhost +
' "kill ' + pid +
'"'
331 p = subprocess.Popen(cmd, shell=
True)
337 def run_roisender(conffile):
338 roihost = get_rfgetconf(conffile,
'roisender',
'ctlhost')
339 basedir = get_rfgetconf(conffile,
'system',
'execdir_base')
340 port = get_rfgetconf(conffile,
'system',
'nsmport')
341 if not os.path.exists(basedir +
'/roisender'):
342 os.mkdir(basedir +
'/roisender')
343 cmd =
'ssh ' + roihost +
' "cd ' + basedir +
'; export NSM2_PORT=' + port \
344 +
'; rf_roisender ' + get_configpath(conffile) \
345 +
' &> roisender/nsmlog.log" '
347 subprocess.Popen(cmd, shell=
True)
353 def stop_roisender(conffile):
354 roihost = get_rfgetconf(conffile,
'roisender',
'ctlhost')
355 basedir = get_rfgetconf(conffile,
'system',
'execdir_base')
356 unit = get_rfgetconf(conffile,
'system',
'unitname')
357 shmname = unit +
':roisender'
358 p = subprocess.Popen(
'rfcommand ' + conffile +
' roisender RF_UNCONFIGURE', shell=
True)
360 pidfile = basedir +
'/roisender/pid.data'
361 for pid
in open(pidfile,
'r'):
362 cmd =
'ssh ' + roihost +
' "kill ' + pid +
'; removeshm ' + shmname +
'"'
364 p = subprocess.Popen(cmd, shell=
True)
370 def run_master(conffile):
371 masterhost = get_rfgetconf(conffile,
'master',
'ctlhost')
372 basedir = get_rfgetconf(conffile,
'system',
'execdir_base')
373 port = get_rfgetconf(conffile,
'system',
'nsmport')
374 if not os.path.exists(basedir +
'/master'):
375 os.mkdir(basedir +
'/master')
376 cmd =
'ssh ' + masterhost +
' "cd ' + basedir +
'; export NSM2_PORT=' \
377 + port +
'; rf_master_local ' + get_configpath(conffile) \
378 +
' &> master/nsmlog.log" '
380 subprocess.Popen(cmd, shell=
True)
386 def stop_master(conffile):
387 masterhost = get_rfgetconf(conffile,
'master',
'ctlhost')
388 basedir = get_rfgetconf(conffile,
'system',
'execdir_base')
391 pidfile = basedir +
'/master/pid.data'
392 for pid
in open(pidfile,
'r'):
393 cmd =
'ssh ' + masterhost +
' "kill ' + pid +
'"'
395 p = subprocess.Popen(cmd, shell=
True)
399 def start_rfarm_components(conffile):
400 run_eventprocessor(conffile)
401 run_outputserver(conffile)
402 run_eventserver(conffile)
403 run_dqmserver(conffile)
404 run_roisender(conffile)
409 def stop_rfarm_components(conffile):
410 stop_roisender(conffile)
411 stop_dqmserver(conffile)
412 stop_eventserver(conffile)
413 stop_outputserver(conffile)
414 stop_eventprocessor(conffile)
419 def start_rfarm_local(conffile):
420 start_rfarm_components(conffile)
426 def stop_rfarm_local(conffile):
428 stop_rfarm_components(conffile)
429 stop_master(conffile)