Chris Dent <cdent+os@anticdent.org> 于2019年4月10日周三 上午1:31写道:

>From the etherpad [1] (the cross project one):

* This came up with the effort to add a multiattach capability
   filter, at https://review.openstack.org/#/c/645316/1/nova/compute/api.py@1098

* The problem: we want to be able to request allocation candidates
   filtered by a trait that exists on the root provider; but

     * (a) the root provider may provide no resources (eventually -
       e.g. CPU/mem in NUMA providers, shared disk); and/or

         * (My brain hurts from the concept for a provider that
           provides nothing. Perhaps it provides something we aren't
           remembering to count?)

     * (b) we are using only numbered groups and would have to guess
       where to stuff the `required` - again probably based on
       looking for the VCPU/mem resources, which, as above, may wind
       up not on the root provider.

Yea, just take a look at this spec https://review.openstack.org/#/c/647578/4, after
we have NUMA in Placement, then the VCPU/mem in the child NUMA RP, but those
traits are still in the root provider.
 

This, basically, is how/when do we deal with resource providers that
have traits but have no classes of inventory of their own (all of it
is on their descendants). The "My brain hurts" comment above is
mine.

The discussion on the review above (good backgrounder for this
thread) had little to do with the immediate need of the proposed
feature. It was a concern about how things will work in the future.
So there are two salient questions (and presumably plenty of other
sidebars):

* How should it work?
* What is the timeline for when it needs to work?

[1] https://etherpad.openstack.org/p/ptg-train-xproj-nova-placement


--
Chris Dent                       ٩◔̯◔۶           https://anticdent.org/
freenode: cdent                                         tw: @anticdent