-
Notifications
You must be signed in to change notification settings - Fork 261
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
additionalBlockDevices
should consider the flavor's OS-FLV-EXT-DATA:ephemeral
property
#2169
Comments
additionalBlockDevices
should take flavor.ephemeral
into considerationadditionalBlockDevices
should consider the flavor's OS-FLV-EXT-DATA:ephemeral
property
Awesome inputs @stephenfin , thanks for looking at it. I see two things here:
|
Mostly agreed on both. I'd probably lean towards an error for the latter case also due to the aforementioned divergence between k8s'/OS' view of the world, but I can see both sides of the argument. |
The Kubernetes project currently lacks enough contributors to adequately respond to all issues. This bot triages un-triaged issues according to the following rules:
You can:
Please send feedback to sig-contributor-experience at kubernetes/community. /lifecycle stale |
/remove-lifecycle stale |
/kind feature
Describe the solution you'd like
(Heads up: this is speculative based on code inspection. I have not yet attempted to reproduce the scenarios described here to prove things work the way I've said. I will though...unless someone beats me to it)
additionalBlockDevices
is expected to represent all non-root block devices attached to the instance. As of #1692, we are able to indicate the type of block device by setting thetype
property of the given block device, which allows us to create Nova-provisioned (a.k.a. "ephemeral") disk as well as the Cinder-provisioned disks previously supported. However, there are two nuances with Nova-provisioned disks that I don't think are accounted for. Firstly, while you can create multiple Nova-provisioned disks, the total capacity of those disks cannot exceed the GB value given in theOS-FLV-EXT-DATA:ephemeral
property of the flavour. This will presumably cause non-obvious reconciler issue if a user tries to create e.g. twolocal
type BDMs of 10GB but the flavor hasOS-FLV-EXT-DATA:ephemeral = 15
. Secondly, if no block device mapping is given but your flavor specifies a non-zero property forOS-FLV-EXT-DATA:ephemeral
, you will still get a single volume corresponding to that property. This won't cause any reconciliation issues, but will lead to a situation where k8s' view of the server resource diverges from OpenStack's, which sounds like a Bad Thing ™️Anything else you would like to add:
I recently wrote a blog about block devices in OpenStack to jot down my own understanding of BDMs in OpenStack. It may or may not be helpful. In any case, it can be found here https://that.guru/blog/block-devices-in-openstack/. Nova's own docs on the matter are spread out but the most important pieces (IMO) can be found here and here.
The text was updated successfully, but these errors were encountered: