Yield to other greenthreads during validation

Validating a large stack locks up a whole worker until it is complete,
because it doesn't co-operate in greenlet's co-operative multithreading.
With this change, we now yield the flow of control between each resource,
so that validation can't monopolise the process.

Validation is high priority because it happens synchronously, but it is
probably worth the trade-off to avoid blocking anything else happening on
the same worker.

Change-Id: I8514640135a915791a0905eea40ef70876ae1cb1
This commit is contained in:
Zane Bitter 2017-05-12 16:36:42 -04:00
parent 9c23f782e7
commit c713cc5d64

View File

@ -864,6 +864,7 @@ class Stack(collections.Mapping):
message=encodeutils.safe_decode(six.text_type(ex)))
if result:
raise exception.StackValidationFailed(message=result)
eventlet.sleep(0)
for op_name, output in six.iteritems(self.outputs):
try: