yahoo-eng-team team mailing list archive
-
yahoo-eng-team team
-
Mailing list archive
-
Message #26203
[Bug 1380776] Re: Uploading and downloading VHDs via Glance XenAPI plugin doesn't always retry when it should
** Changed in: nova
Status: Fix Committed => Fix Released
** Changed in: nova
Milestone: None => kilo-1
--
You received this bug notification because you are a member of Yahoo!
Engineering Team, which is subscribed to OpenStack Compute (nova).
https://bugs.launchpad.net/bugs/1380776
Title:
Uploading and downloading VHDs via Glance XenAPI plugin doesn't always
retry when it should
Status in OpenStack Compute (Nova):
Fix Released
Bug description:
Encountered a situation where one glance node could not talk to
registry which resulted in a high number of upload_vhd errors. The
Glance XenAPI plugin doesn't properly differentiate between server
permanent and globally permanent errors. This is only reasonable
behavior in the case where there is a single glance node. In the case
of many glance nodes retrying a different server is preferable.
Ideally:
Retry until:
1. A non-retryable error is encountered (e.g. 403)
2. Max retries is reached
3. No servers left to retry (i.e. every server was dropped from the retry list due to a permanent error)
If the glance nodes sit behind a load balancer (proxy), this approach
could result in the LB being treated as a single glance endpoint (no
retries for server errors). Retrying on server errors without dropping
servers with server errors from the list could result in unnecessary
retries, especially in the case where there is only a single glance
node.
Additionally, if multiple errors are encountered, only the last error is logged as an instance error. Every error should be recorded.
Examples:
Current:
* The plugin tries to upload using 1 of n glance nodes (n > 1)
* An ephemeral (retryable) error is encountered
* The plugin retries using a different glance node
* An error related to a server fault (e.g. 500) is encountered
* The plugin does not retry
* Instance fault
Expected:
* The plugin tries to upload using 1 of n glance nodes (n > 1)
* An ephemeral (retryable) error is encountered
* Instance fault
* The plugin retries using a different glance node
* An error related to a server fault (e.g. 500) is encountered
* The plugin retries using a different glance node
* Success
To manage notifications about this bug go to:
https://bugs.launchpad.net/nova/+bug/1380776/+subscriptions
References