Open
Description
Task类的run方法内有两个循环,最外面循环只有在stop事件出现后才出退出, 为什么?
def run(self):
try:
curr_priority = 0
while not self.stopped.is_set():
priority_name = 'inc' if curr_priority == self.n_priorities \
else curr_priority
is_inc = priority_name == 'inc'
while not self.nonsuspend.wait(5):
continue
if self.stopped.is_set():
break
self.logger.debug('start to process priority: %s' % priority_name)
last = self.priorities_secs[curr_priority]
clock = Clock()
runnings = []
try:
no_budgets_times = 0
while not self.stopped.is_set():
if clock.clock() >= last:
break
if not is_inc:
status = self._apply(no_budgets_times)
if status == CANNOT_APPLY:
break
elif status == APPLY_FAIL:
no_budgets_times += 1
if not self._has_not_finished(curr_priority) and \
len(runnings) == 0:
continue
if self._has_not_finished(curr_priority) and \
len(runnings) == 0:
self._get_unit(curr_priority, runnings)
else:
no_budgets_times = 0
self._get_unit(curr_priority, runnings)
else:
self._get_unit(curr_priority, runnings)
if len(runnings) == 0:
break
if self.is_bundle:
self.logger.debug(
'process bundle from priority %s' % priority_name)
rest = min(last - clock.clock(), MAX_BUNDLE_RUNNING_SECONDS)
if rest <= 0:
break
obj = self.executor.execute(runnings.pop(), rest, is_inc=is_inc)
else:
obj = self.executor.execute(runnings.pop(), is_inc=is_inc)
if obj is not None:
runnings.insert(0, obj)
finally:
self.priorities_objs[curr_priority].extend(runnings)
curr_priority = (curr_priority+1) % self.full_priorities
finally:
self.counter_client.sync()
self.save()
Metadata
Metadata
Assignees
Labels
No labels