I totally agree on this meta level scheduler aspect. This should separate the placement decision making logic (for resources of any type, but can start on Nova resources) from their actual creation, say VM creation.
This way the placement decisions can be relayed to the individual components "allocator" component or whatever component that handles this after the separation. So in this effort of separating the scheduler I hope some clean interfaces will be created that separate these logics. At least we should attempt to make the effort follow some global meta scheduling clean interfaces that should be designed. Yathi. ------ Original message------ From: Debojyoti Dutta Date: Tue, 12/3/2013 10:50 AM To: OpenStack Development Mailing List (not for usage questions); Cc: Boris Pavlovic; Subject:Re: [openstack-dev] [Nova][Schduler] Volunteers wanted for a modest proposal for an external scheduler in our lifetime I agree with RussellB on this … if the forklift's goal is to just separate the scheduler, there should be no new features etc till the forklift is done and it should work as is with very minor config changes. A scheduler has several features like place resources correctly, for example. Ideally, this should be a simple service that can allocate any resources to any available bucket - balls in bins, VMs in host, blocks/blobs on disk/SSD etc. Maybe the scheduler should operate on meta level resource maps for each "type" and delegate the precise decisions to the allocator for that "type". debo On Tue, Dec 3, 2013 at 9:58 AM, Russell Bryant <rbry...@redhat.com<mailto:rbry...@redhat.com>> wrote: On 12/03/2013 07:22 AM, Boris Pavlovic wrote: > Hi all, > > > Finally found a bit time to write my thoughts. > > There are few blockers that make really complex to build scheduler as a > services or even to move main part of scheduler code to separated lib. > We already have one unsuccessfully effort > https://blueprints.launchpad.net/oslo/+spec/oslo-scheduler . > > Major problems that we faced were next: > 1) Hard connection with project db api layer (e.g. nova.db.api, > cinder.db.api) > 2) Hard connection between db.models and host_states > 3) Hardcoded host states objects structure > 4) There is no namespace support in host states (so we are not able to > keep all filters for all projects in the same place) > 5) Different API methods, that can't be effectively generalized. > > > Main goals of no-db-scheduler effort are: > 1) Make scheduling much faster, storing data locally on each scheduler > and just syncing states of them > 2) Remove connections between project.db.api and scheduler.db > 3) Make host_states just JSON like objects > 4) Add namespace support in host_states > > When this part will be finished, we will have actually only 1 problem > what to do with DB API methods, and business logic of each project. What > I see is that there are 2 different ways: If the new project is just a forklift of the existing code that still imports nova's db API and accesses Nova's DB, I don't think the initial forklift necessarily has to be blocked on completing no-db-scheduler. That can happen after just as easily (depending on which effort is ready first). > 1) Make scheduler as a big lib, then implement RPC methods + bit of > business logic in each project > 2) Move all RPC calls from nova,cinder,ironic,... and business logic in > 1 scheduler as a service Right now I think #2 is the approach we should take. This is mainly because there is common information that is needed for the scheduling logic for resources in multiple projects. -- Russell Bryant _______________________________________________ OpenStack-dev mailing list OpenStack-dev@lists.openstack.org<mailto:OpenStack-dev@lists.openstack.org> http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev -- -Debo~
_______________________________________________ OpenStack-dev mailing list OpenStack-dev@lists.openstack.org http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev