8b381c7324
Agent object has been merged [1]. This patch uses Agent object in agents_db and test_agents_db. We also introduce a new function (get_agents_object) and keep the old function (get_agents_db) for backward compatibility. [1] https://review.openstack.org/#/c/297887/ Co-Authored-By: Nguyen Phuong An <AnNP@vn.fujitsu.com> Change-Id: I4c4283cb1aa05d52dca00cc249e094ea7d55b1d3 Partially-Implements: blueprint adopt-oslo-versioned-objects-for-db
43 lines
1.8 KiB
Python
43 lines
1.8 KiB
Python
# Copyright (c) 2015 OpenStack Foundation.
|
|
# All Rights Reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
import abc
|
|
|
|
import six
|
|
|
|
|
|
@six.add_metaclass(abc.ABCMeta)
|
|
class BaseResourceFilter(object):
|
|
"""Encapsulate logic that is specific to the resource type."""
|
|
@abc.abstractmethod
|
|
def filter_agents(self, plugin, context, resource):
|
|
"""Return the agents that can host the resource."""
|
|
|
|
def bind(self, context, agents, resource_id):
|
|
"""Bind the resource to the agents."""
|
|
with context.session.begin(subtransactions=True):
|
|
for agent in agents:
|
|
# Load is being incremented here to reflect latest agent load
|
|
# even within the agent report interval. This will be very
|
|
# much necessary when bulk resource creation happens within a
|
|
# agent report interval time.
|
|
# NOTE: The resource being bound might or might not be of the
|
|
# same type which is accounted for the load. It isn't a
|
|
# problem because "+ 1" here does not meant to predict
|
|
# precisely what the load of the agent will be. The value will
|
|
# be corrected by the agent on the next report interval.
|
|
agent.load += 1
|
|
agent.update()
|