← Back to team overview

yahoo-eng-team team mailing list archive

[Bug 1978294] Re: [NFS/Quobyte/NetApp] No feedback from Nova when extending attached Volumes

 

** Also affects: nova
   Importance: Undecided
       Status: New

** Changed in: nova
       Status: New => In Progress

** Changed in: nova
     Assignee: (unassigned) => Konrad Gube (kgube)

-- 
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/1978294

Title:
  [NFS/Quobyte/NetApp] No feedback from Nova when extending attached
  Volumes

Status in Cinder:
  In Progress
Status in OpenStack Compute (nova):
  In Progress

Bug description:
  When extending an attached Volume, Cinder will notify Nova after
  running the volume driver's extend_volume method, so that Nova can
  take steps to make the additional space available to the instance the
  volume is attached to.

  Nova is notified using the external server event API [1], which is an asynchronous operation and has no effect on the volume status or the success of the extend.
  For most drivers this is fine, but there are proposed changes to the NFS [2] and NetApp [3] drivers that rely on Nova to perform the actual resize if the volume is attached.
  A failure to resize by Nova would then lead to an inconsistent volume status and size, because currently both are set before Nova even gets notified of the resize.

  Lucio Seki, who first worked on [2] and [3], collected some thoughts
  on this in an etherpad [4] together with other potential issues of the
  changes.

  There are essentially two approaches to fixing this:

  1. Have Cinder poll Nova for the completion.
  Might require [5] to get fixed, to make resize failures show up in the instance action log.
  Cinder would then poll the actions log of the instance to get the status of the operation and update the volume status accordingly.

  2. Have Nova call back into Cinder when the resize is finished.
  The "os-reset_status" volume action could perhaps be abused for this, but a cleaner solution would be the introduction of a new volume action, akin to "os-migrate_volume_completion".

  I believe a new volume action would be the best way to implement this, and I would like to work on this, with the goal of getting [2] and [3] merged eventually.
  I'm new to Cinder development though, so I am very happy about any suggestions or feedback.

  [1]: https://docs.openstack.org/api-ref/compute/?expanded=run-events-detail#run-events
  [2]: https://review.opendev.org/c/openstack/cinder/+/739079
  [3]: https://review.opendev.org/c/openstack/cinder/+/820578
  [4]: https://etherpad.opendev.org/p/fix-nfs-online-extend
  [5]: https://review.opendev.org/c/openstack/nova/+/680648/

To manage notifications about this bug go to:
https://bugs.launchpad.net/cinder/+bug/1978294/+subscriptions