Strategies can require, from Watcher, metrics collected on the IAAS. Watcher uses only Ceilometer API to retrieve metrics. Change the metrics database backend, add a new metric is not in the scope of Watcher, but rather in the Ceilometer one. We add some links to Ceilometer documentation about these topics. Change-Id: If37c7df8e5852f5ecf94b4a9eb9c8c91fe6637eb
6.8 KiB
Build a new optimization strategy
Watcher Decision Engine has an external strategy <strategy_definition>
plugin interface
which gives anyone the ability to integrate an external strategy <strategy_definition>
in order to make
use of placement algorithms.
This section gives some guidelines on how to implement and integrate custom Stategies with Watcher.
Pre-requisites
Before using any strategy, you should make sure you have your Telemetry service configured so that it would provide you all the metrics you need to be able to use your strategy.
Creating a new plugin
First of all you have to:
- Extend the base
BaseStrategy
class - Implement its
execute
method
Here is an example showing how you can write a plugin called
DummyStrategy
:
# Filepath = third-party/third_party/dummy.py
# Import path = third_party.dummy
class DummyStrategy(BaseStrategy):
= "dummy"
DEFAULT_NAME = "Dummy Strategy"
DEFAULT_DESCRIPTION
def __init__(self, name=DEFAULT_NAME, description=DEFAULT_DESCRIPTION):
super(DummyStrategy, self).__init__(name, description)
def execute(self, model):
self.solution.add_change_request(
=my_vm, src_hypervisor=src, dest_hypervisor=dest)
Migrate(vm
)# Do some more stuff here ...
return self.solution
As you can see in the above example, the execute()
method returns a solution as required.
Please note that your strategy class will be instantiated without any
parameter. Therefore, you should make sure not to make any of them
required in your __init__
method.
Abstract Plugin Class
Here below is the abstract BaseStrategy
class that every
single strategy should implement:
watcher.decision_engine.strategy.strategies.base
BaseStrategy
Add a new entry point
In order for the Watcher Decision Engine to load your new strategy,
the strategy must be registered as a named entry point under the
watcher_strategies
entry point of your
setup.py
file. If you are using pbr, this entry
point should be placed in your setup.cfg
file.
The name you give to your entry point has to be unique.
Here below is how you would proceed to register
DummyStrategy
using pbr:
[entry_points]
watcher_strategies =
dummy = third_party.dummy:DummyStrategy
To get a better understanding on how to implement a more advanced
strategy, have a look at the :pyBasicConsolidation
class.
Using strategy plugins
The Watcher Decision Engine service will automatically discover any installed plugins when it is run. If a Python package containing a custom plugin is installed within the same environment as Watcher, Watcher will automatically make that plugin available for use.
At this point, the way Watcher will use your new strategy if you
reference it in the goals
under the
[watcher_goals]
section of your watcher.conf
configuration file. For example, if you want to use a dummy
strategy you just installed, you would have to associate it to a goal
like this:
[watcher_goals]
goals = BALANCE_LOAD:basic,MINIMIZE_ENERGY_CONSUMPTION:dummy
You should take care when installing strategy plugins. By their very nature, there are no guarantees that utilizing them as is will be supported, as they may require a set of metrics which is not yet available within the Telemetry service. In such a case, please do make sure that you first check/configure the latter so your new strategy can be fully functional.
Querying metrics
A large set of metrics, generated by OpenStack modules, can be used in your strategy implementation. To collect these metrics, Watcher provides a Helper to the Ceilometer API, which makes this API reusable and easier to used.
If you want to use your own metrics database backend, please refer to the Ceilometer developer guide. Indeed, Ceilometer's pluggable model allows for various types of backends. A list of the available backends is located here. The Ceilosca project is a good example of how to create your own pluggable backend.
Finally, if your strategy requires new metrics not covered by Ceilometer, you can add them through a Ceilometer plugin.
Read usage metrics using the Python binding
You can find the information about the Ceilometer Python binding on the OpenStack ceilometer client python API documentation
The first step is to authenticate against the Ceilometer service (assuming that you already imported the Ceilometer client for Python) with this call:
= ceilometerclient.client.get_client(VERSION, os_username=USERNAME,
cclient =PASSWORD, os_tenant_name=PROJECT_NAME, os_auth_url=AUTH_URL) os_password
Using that you can now query the values for that specific metric:
= cclient.samples.list(meter_name='cpu_util', limit=10, q=query) value_cpu
Read usage metrics using the Watcher Cluster History Helper
Here below is the abstract BaseClusterHistory
class of
the Helper.
watcher.metrics_engine.cluster_history.api
BaseClusterHistory
The following snippet code shows how to create a Cluster History class:
= CeilometerClusterHistory() query_history
Using that you can now query the values for that specific metric:
=hypervisor.uuid,
query_history.statistic_aggregation(resource_id='compute.node.cpu.percent',
meter_name="7200",
period='avg'
aggregate )