On Thu, 13 Jul 2017, Balazs Gibizer wrote:
but placement returns an empty response. Then nova scheduler falls back to
legacy behavior  and places the instance without considering the custom
As far as I can tell at least one missing piece of the puzzle here
is that your MAGIC provider does not have the
'MISCSHARESVIA_AGGREGATE' trait. It's not enough for the compute
and MAGIC to be in the same aggregate, the MAGIC needs to announce
that its inventory is for sharing. The comments here have a bit more
It's quite likely this is not well documented yet as this style of
declaring that something is shared was a later development. The
initial code that added the support for GET /resourceproviders
was around, it was later reused for GET /allocationcandidates:
The other thing to be aware of is that GET /allocation_candidates is
in flight. It should be stable on the placement service side, but the
way the data is being used on the scheduler side is undergoing
change as we speak:
Then I tried to connect the compute provider and the MAGIC provider to the
same aggregate via the placement API but the above placement request still
resulted in empty response. See my exact steps in .
This still needs to happen, but you also need to put the trait
mentioned above on the magic provider, the docs for that are in progress
on this review
and a rendered version:
Do I still missing some environment setup on my side to make it work?
Is the work in  incomplete?
Are the missing pieces in  needed to make this use case work?
If more implementation is needed then I can offer some help during Queens
There's definitely more to do and your help would be greatly
appreciated. It's fantastic that you are experimenting with this
and sharing what's happening.
To make the above use case fully functional I realized that I need a service
that periodically updates the placement service with the state of the MAGIC
resource like the resource tracker in Nova. Is there any existing plans
creating a generic service or framework that can be used for the tracking and
As you've probably discovered from your experiments with curl,
updating inventory is pretty straightforward (if you have a TOKEN)
so we decided to forego making a framework at this point. I had some
code long ago that demonstrated one way to do it, but it didn't get
That tried to be a simple python script using requests that did the
bare minimum and would be amenable to cron jobs and other simple
I hope some of the above is helpful. Jay, Ed, Sylvain or Dan may come
along with additional info.
Chris Dent ┬──┬◡ﾉ(° -°ﾉ) https://anticdent.org/
freenode: cdent tw: @anticdent__________________________________________________________________________
OpenStack Development Mailing List (not for usage questions)