[Openstack-operators] [nova] FYI on changes that might impact out of tree scheduler filters
Matt Riedemann
mriedemos at gmail.com
Thu May 17 20:36:01 UTC 2018
CERN has upgraded to Cells v2 and is doing performance testing of the
scheduler and were reporting some things today which got us back to this
bug [1]. So I've starting pushing some patches related to this but also
related to an older blueprint I created [2]. In summary, we do quite a
bit of DB work just to load up a list of instance objects per host that
the in-tree filters don't even use.
The first change [3] is a simple optimization to avoid the default joins
on the instance_info_caches and security_groups tables. If you have out
of tree filters that, for whatever reason, rely on the
HostState.instances objects to have info_cache or security_groups set,
they'll continue to work, but will have to round-trip to the DB to
lazy-load the fields, which is going to be a performance penalty on that
filter. See the change for details.
The second change in the series [4] is more drastic in that we'll do
away with pulling the full Instance object per host, which means only a
select set of optional fields can be lazy-loaded [5], and the rest will
result in an exception. The patch currently has a workaround config
option to continue doing things the old way if you have out of tree
filters that rely on this, but for good citizens with only in-tree
filters, you will get a performance improvement during scheduling.
There are some other things we can do to optimize more of this flow, but
this email is just about the ones that have patches up right now.
[1] https://bugs.launchpad.net/nova/+bug/1737465
[2]
https://blueprints.launchpad.net/nova/+spec/put-host-manager-instance-info-on-a-diet
[3] https://review.openstack.org/#/c/569218/
[4] https://review.openstack.org/#/c/569247/
[5]
https://github.com/openstack/nova/blob/de52fefa1fd52ccaac6807e5010c5f2a2dcbaab5/nova/objects/instance.py#L66
--
Thanks,
Matt
More information about the OpenStack-operators
mailing list