os-faults/examples/power_off_on_ipmi_node.py
Anton Studenov 3954065549 Allow usage of multiple power drivers at once
* Deprecated power_management parameter.
* Added power_managements to configuration.
* Removed power_management variable from NodeCollection
  and Service.
* Added PowerManager class that controls running of
  power drivers.
* Updated docs.

Change-Id: Idabcb1fb907022f0d556667cbf3c36326f526a08
2017-01-25 12:58:36 +03:00

72 lines
2.0 KiB
Python

# 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 logging
import os_faults
def main():
# cloud config schema is an extension to os-client-config
cloud_config = {
'cloud_management': {
'driver': 'fuel',
'args': {
'address': 'fuel.local',
'username': 'root',
}
},
'power_managements': [
{
'driver': 'ipmi',
'args': {
'mac_to_bmc': {
'00:00:00:00:00:00': {
'address': '55.55.55.55',
'username': 'foo',
'password': 'bar',
}
}
}
}
]
}
logging.info('Create connection to the cluster')
destructor = os_faults.connect(cloud_config)
logging.info('Verify connection to the cluster')
destructor.verify()
logging.info('Get all cluster nodes')
nodes = destructor.get_nodes()
logging.info('All cluster nodes: %s', nodes)
computes = nodes.filter(role='compute')
one = computes.pick()
logging.info('Pick one of compute nodes: %s', one)
logging.info('Power off compute node')
one.poweroff()
logging.info('Power on compute node')
one.poweron()
logging.info('Done!')
if __name__ == '__main__':
logging.basicConfig(format='%(asctime)s %(levelname)s %(message)s',
level=logging.DEBUG)
main()