857372a226
IPMISocatConsole is a new console interface class using ipmitool and socat. It has the same APIs of IPMIShellinaboxConsole class and provides TCP4/TCP6 connection service to connect serial-on-LAN of nodes. IPMIConsole is a new console interface class using ipmitool and used as parent class of IPMIShellinaboxConsole and IPMISocatConsol class. This patch set implements new console driver interfaces IPMISocatConsole. To use PXE + IPMItool + socat, specify pxe_ipmitool_socat. To use IPA + IPMItool + socat, specify agent_ipmitool_socat. Spec: https://review.openstack.org/#/c/319505/ Partial-Bug: #1553083 Change-Id: I35a7dcb7e89baf16d096501fd44dbc12adc8c61e
278 lines
11 KiB
Python
278 lines
11 KiB
Python
# Copyright 2014 Rackspace, Inc.
|
|
#
|
|
# 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.
|
|
|
|
from oslo_utils import importutils
|
|
|
|
from ironic.common import exception
|
|
from ironic.common.i18n import _
|
|
from ironic.drivers import base
|
|
from ironic.drivers.modules import agent
|
|
from ironic.drivers.modules.amt import management as amt_management
|
|
from ironic.drivers.modules.amt import power as amt_power
|
|
from ironic.drivers.modules.cimc import management as cimc_mgmt
|
|
from ironic.drivers.modules.cimc import power as cimc_power
|
|
from ironic.drivers.modules import iboot
|
|
from ironic.drivers.modules import inspector
|
|
from ironic.drivers.modules import ipminative
|
|
from ironic.drivers.modules import ipmitool
|
|
from ironic.drivers.modules import pxe
|
|
from ironic.drivers.modules import ssh
|
|
from ironic.drivers.modules.ucs import management as ucs_mgmt
|
|
from ironic.drivers.modules.ucs import power as ucs_power
|
|
from ironic.drivers.modules import virtualbox
|
|
from ironic.drivers.modules import wol
|
|
from ironic.drivers import utils
|
|
|
|
|
|
class AgentAndIPMIToolDriver(base.BaseDriver):
|
|
"""Agent + IPMITool driver.
|
|
|
|
This driver implements the `core` functionality, combining
|
|
:class:`ironic.drivers.modules.ipmitool.IPMIPower` (for power on/off and
|
|
reboot) with :class:`ironic.drivers.modules.agent.AgentDeploy` (for
|
|
image deployment).
|
|
Implementations are in those respective classes; this class is merely the
|
|
glue between them.
|
|
"""
|
|
|
|
def __init__(self):
|
|
self.power = ipmitool.IPMIPower()
|
|
self.boot = pxe.PXEBoot()
|
|
self.deploy = agent.AgentDeploy()
|
|
self.management = ipmitool.IPMIManagement()
|
|
self.console = ipmitool.IPMIShellinaboxConsole()
|
|
self.agent_vendor = agent.AgentVendorInterface()
|
|
self.ipmi_vendor = ipmitool.VendorPassthru()
|
|
self.mapping = {'send_raw': self.ipmi_vendor,
|
|
'bmc_reset': self.ipmi_vendor,
|
|
'heartbeat': self.agent_vendor}
|
|
self.driver_passthru_mapping = {'lookup': self.agent_vendor}
|
|
self.vendor = utils.MixinVendorInterface(
|
|
self.mapping,
|
|
driver_passthru_mapping=self.driver_passthru_mapping)
|
|
self.raid = agent.AgentRAID()
|
|
self.inspect = inspector.Inspector.create_if_enabled(
|
|
'AgentAndIPMIToolDriver')
|
|
|
|
|
|
class AgentAndIPMIToolAndSocatDriver(AgentAndIPMIToolDriver):
|
|
"""Agent + IPMITool + socat driver.
|
|
|
|
This driver implements the `core` functionality, combining
|
|
:class:`ironic.drivers.modules.ipmitool.IPMIPower` (for power on/off and
|
|
reboot) with :class:`ironic.drivers.modules.agent.AgentDeploy` (for
|
|
image deployment) and with
|
|
:class:`ironic.drivers.modules.ipmitool.IPMISocatConsole`.
|
|
This driver uses the socat console interface instead of the shellinabox
|
|
one.
|
|
Implementations are in those respective classes; this class is merely the
|
|
glue between them.
|
|
"""
|
|
|
|
def __init__(self):
|
|
AgentAndIPMIToolDriver.__init__(self)
|
|
self.console = ipmitool.IPMISocatConsole()
|
|
|
|
|
|
class AgentAndIPMINativeDriver(base.BaseDriver):
|
|
"""Agent + IPMINative driver.
|
|
|
|
This driver implements the `core` functionality, combining
|
|
:class:`ironic.drivers.modules.ipminative.NativeIPMIPower` (for power
|
|
on/off and reboot) with
|
|
:class:`ironic.drivers.modules.agent.AgentDeploy` (for image
|
|
deployment).
|
|
Implementations are in those respective classes; this class is merely the
|
|
glue between them.
|
|
"""
|
|
|
|
def __init__(self):
|
|
self.power = ipminative.NativeIPMIPower()
|
|
self.boot = pxe.PXEBoot()
|
|
self.deploy = agent.AgentDeploy()
|
|
self.management = ipminative.NativeIPMIManagement()
|
|
self.console = ipminative.NativeIPMIShellinaboxConsole()
|
|
self.agent_vendor = agent.AgentVendorInterface()
|
|
self.ipminative_vendor = ipminative.VendorPassthru()
|
|
self.mapping = {
|
|
'send_raw': self.ipminative_vendor,
|
|
'bmc_reset': self.ipminative_vendor,
|
|
'heartbeat': self.agent_vendor,
|
|
}
|
|
self.driver_passthru_mapping = {'lookup': self.agent_vendor}
|
|
self.vendor = utils.MixinVendorInterface(self.mapping,
|
|
self.driver_passthru_mapping)
|
|
self.raid = agent.AgentRAID()
|
|
self.inspect = inspector.Inspector.create_if_enabled(
|
|
'AgentAndIPMINativeDriver')
|
|
|
|
|
|
class AgentAndSSHDriver(base.BaseDriver):
|
|
"""Agent + SSH driver.
|
|
|
|
NOTE: This driver is meant only for testing environments.
|
|
|
|
This driver implements the `core` functionality, combining
|
|
:class:`ironic.drivers.modules.ssh.SSH` (for power on/off and reboot of
|
|
virtual machines tunneled over SSH), with
|
|
:class:`ironic.drivers.modules.agent.AgentDeploy` (for image
|
|
deployment). Implementations are in those respective classes; this class
|
|
is merely the glue between them.
|
|
"""
|
|
|
|
def __init__(self):
|
|
self.power = ssh.SSHPower()
|
|
self.boot = pxe.PXEBoot()
|
|
self.deploy = agent.AgentDeploy()
|
|
self.management = ssh.SSHManagement()
|
|
self.vendor = agent.AgentVendorInterface()
|
|
self.raid = agent.AgentRAID()
|
|
self.inspect = inspector.Inspector.create_if_enabled(
|
|
'AgentAndSSHDriver')
|
|
self.console = ssh.ShellinaboxConsole()
|
|
|
|
|
|
class AgentAndVirtualBoxDriver(base.BaseDriver):
|
|
"""Agent + VirtualBox driver.
|
|
|
|
NOTE: This driver is meant only for testing environments.
|
|
|
|
This driver implements the `core` functionality, combining
|
|
:class:`ironic.drivers.modules.virtualbox.VirtualBoxPower` (for power
|
|
on/off and reboot of VirtualBox virtual machines), with
|
|
:class:`ironic.drivers.modules.agent.AgentDeploy` (for image
|
|
deployment). Implementations are in those respective classes; this class
|
|
is merely the glue between them.
|
|
"""
|
|
|
|
def __init__(self):
|
|
if not importutils.try_import('pyremotevbox'):
|
|
raise exception.DriverLoadError(
|
|
driver=self.__class__.__name__,
|
|
reason=_("Unable to import pyremotevbox library"))
|
|
self.power = virtualbox.VirtualBoxPower()
|
|
self.boot = pxe.PXEBoot()
|
|
self.deploy = agent.AgentDeploy()
|
|
self.management = virtualbox.VirtualBoxManagement()
|
|
self.vendor = agent.AgentVendorInterface()
|
|
self.raid = agent.AgentRAID()
|
|
|
|
|
|
class AgentAndAMTDriver(base.BaseDriver):
|
|
"""Agent + AMT driver.
|
|
|
|
This driver implements the `core` functionality, combining
|
|
:class:`ironic.drivers.amt.AMTPower` for power on/off and reboot with
|
|
:class:`ironic.drivers.modules.agent_deploy.AgentDeploy` for image
|
|
deployment. Implementations are in those respective classes; this
|
|
class is merely the glue between them.
|
|
"""
|
|
def __init__(self):
|
|
if not importutils.try_import('pywsman'):
|
|
raise exception.DriverLoadError(
|
|
driver=self.__class__.__name__,
|
|
reason=_("Unable to import pywsman library"))
|
|
self.power = amt_power.AMTPower()
|
|
self.boot = pxe.PXEBoot()
|
|
self.deploy = agent.AgentDeploy()
|
|
self.management = amt_management.AMTManagement()
|
|
self.vendor = agent.AgentVendorInterface()
|
|
|
|
|
|
class AgentAndUcsDriver(base.BaseDriver):
|
|
"""Agent + Cisco UCSM driver.
|
|
|
|
This driver implements the `core` functionality, combining
|
|
:class:ironic.drivers.modules.ucs.power.Power for power
|
|
on/off and reboot with
|
|
:class:'ironic.driver.modules.agent.AgentDeploy' (for image deployment.)
|
|
Implementations are in those respective classes;
|
|
this class is merely the glue between them.
|
|
"""
|
|
|
|
def __init__(self):
|
|
if not importutils.try_import('UcsSdk'):
|
|
raise exception.DriverLoadError(
|
|
driver=self.__class__.__name__,
|
|
reason=_("Unable to import UcsSdk library"))
|
|
self.power = ucs_power.Power()
|
|
self.boot = pxe.PXEBoot()
|
|
self.deploy = agent.AgentDeploy()
|
|
self.management = ucs_mgmt.UcsManagement()
|
|
self.vendor = agent.AgentVendorInterface()
|
|
self.inspect = inspector.Inspector.create_if_enabled(
|
|
'AgentAndUcsDriver')
|
|
|
|
|
|
class AgentAndCIMCDriver(base.BaseDriver):
|
|
"""Agent + Cisco CIMC driver.
|
|
|
|
This driver implements the `core` functionality, combining
|
|
:class:ironic.drivers.modules.cimc.power.Power for power
|
|
on/off and reboot with
|
|
:class:'ironic.driver.modules.agent.AgentDeploy' (for image deployment.)
|
|
Implementations are in those respective classes;
|
|
this class is merely the glue between them.
|
|
"""
|
|
|
|
def __init__(self):
|
|
if not importutils.try_import('ImcSdk'):
|
|
raise exception.DriverLoadError(
|
|
driver=self.__class__.__name__,
|
|
reason=_("Unable to import ImcSdk library"))
|
|
self.power = cimc_power.Power()
|
|
self.boot = pxe.PXEBoot()
|
|
self.deploy = agent.AgentDeploy()
|
|
self.management = cimc_mgmt.CIMCManagement()
|
|
self.vendor = agent.AgentVendorInterface()
|
|
self.inspect = inspector.Inspector.create_if_enabled(
|
|
'AgentAndCIMCDriver')
|
|
|
|
|
|
class AgentAndWakeOnLanDriver(base.BaseDriver):
|
|
"""Agent + WakeOnLan driver.
|
|
|
|
This driver implements the `core` functionality, combining
|
|
:class:`ironic.drivers.modules.wol.WakeOnLanPower` for power on with
|
|
:class:'ironic.driver.modules.agent.AgentDeploy' (for image deployment.)
|
|
Implementations are in those respective classes;
|
|
this class is merely the glue between them.
|
|
"""
|
|
def __init__(self):
|
|
self.power = wol.WakeOnLanPower()
|
|
self.boot = pxe.PXEBoot()
|
|
self.deploy = agent.AgentDeploy()
|
|
self.vendor = agent.AgentVendorInterface()
|
|
|
|
|
|
class AgentAndIBootDriver(base.BaseDriver):
|
|
"""Agent + IBoot PDU driver.
|
|
|
|
This driver implements the `core` functionality, combining
|
|
:class:`ironic.drivers.modules.iboot.IBootPower` for power
|
|
on/off and reboot with
|
|
:class:'ironic.driver.modules.agent.AgentDeploy' (for image deployment.)
|
|
Implementations are in those respective classes;
|
|
this class is merely the glue between them.
|
|
"""
|
|
def __init__(self):
|
|
if not importutils.try_import('iboot'):
|
|
raise exception.DriverLoadError(
|
|
driver=self.__class__.__name__,
|
|
reason=_("Unable to import iboot library"))
|
|
self.power = iboot.IBootPower()
|
|
self.boot = pxe.PXEBoot()
|
|
self.deploy = agent.AgentDeploy()
|
|
self.vendor = agent.AgentVendorInterface()
|