mirror of
https://github.com/xcat2/confluent.git
synced 2025-01-09 04:56:12 +00:00
Rework ipmi worker management
Provide a more concrete measurement of children, rather than relying upon a sentinel value on the queue. It seems that even using 'finally' didn't assure that we always get that sentinel value before a worker dies. Sentinel value still used to avoid a long wait in the usual case.
This commit is contained in:
parent
b14a53a226
commit
cf97bbe299
@ -273,17 +273,23 @@ def perform_requests(operator, nodes, element, cfg, inputdata):
|
||||
configdata = cfg.get_node_attributes(nodes, _configattributes)
|
||||
cfg.decrypt = cryptit
|
||||
resultdata = queue.LightQueue()
|
||||
pendingnum = len(nodes)
|
||||
livingthreads = set([])
|
||||
for node in nodes:
|
||||
_ipmiworkers.spawn_n(
|
||||
livingthreads.add(_ipmiworkers.spawn(
|
||||
perform_request, operator, node, element, configdata, inputdata,
|
||||
cfg, resultdata)
|
||||
while pendingnum:
|
||||
datum = resultdata.get()
|
||||
if datum == 'Done':
|
||||
pendingnum -= 1
|
||||
else:
|
||||
yield datum
|
||||
cfg, resultdata))
|
||||
while livingthreads:
|
||||
try:
|
||||
datum = resultdata.get(timeout=10)
|
||||
while datum:
|
||||
if datum != 'Done':
|
||||
yield datum
|
||||
datum = resultdata.get_nowait()
|
||||
except queue.Empty:
|
||||
pass
|
||||
for t in list(livingthreads):
|
||||
if t.dead:
|
||||
livingthreads.discard(t)
|
||||
|
||||
|
||||
def perform_request(operator, node, element,
|
||||
|
Loading…
Reference in New Issue
Block a user